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This is an application for a Provisional Patent pursuant to 35 USC § 1 1 1 (b) 
Consumer Care Management Method and System 

by 

" Betty Bird, 
Martin S. Yablonski, 
Joseph R. Laurenzano 

BACKGROUND 

The number of people in need of vision rehabilitation services is growing 
exponentially-particularlyjas the older adult population continues to live longer. People 
who are blind or partially sighted often require a variety of vision rehabilitation services. 
A specialized low vision eye exam to determine the extent of vision loss, the prescription 
of and training in the use of optical devices to help maximize remaining vision, and 
services to promote independent and productive living (such as orientation and mobility 
(safe travel) skills, personal grooming, cooking safely, etc.) need to be monitored, 
adjusted and assessed according to a standard of service delivery. 

While the health care field has for years worked within a universally recognized 
standard of service delivery, outcomes, and quality assurance, the vision rehabilitation 
field has never developed a similar standard. There has been no way to concretely track 
the success of various vision rehabilitation therapies, collect a repository of data, and 
follow a trajectory for the individual receiving services. This type of information is 
valuable for people with vision loss and their families, as well as for service providers 
like the Lighthouse International (herein "Lighthouse") and other organizations. 

• Clearly there is a need for a standardized method to concretely track the success 
of various vision rehabilitation therapies, collect a repository of data, and follow a 



trajectory for the individual receiving services (herein "consumer") in the field of vision 
rehabilitation. 

SUMMARY 

5 

The innovative Electronic Vision Rehabilitation Record software program and 
system (herein "EVRR")> designed and implemented by Lighthouse International, will be 
shared through web technology with vision rehabilitation organizations throughout the 
New York area and the country. The database will constitute the first national database 
10 for benchmarking and setting standards in the field of vision rehabilitation. The EVRR 
will also have national implications for people in need of services, and the 
reimbursements that they are entitled to from managed care organizations and Medicare. 

It is an object of the present invention to function as an appointment scheduler 
accessible to all service provider members and manage resources. 
15 It is another object of the present invention to provide templates of predetermined 

clinical pathways and related care by supplying detailed functional questions in each 
assessment area (currently Independent Living, Mobility, Psychotherapy, Employment, 
Computer Training, Academic Skills, Social Services, Low Vision). 

It is a further object of the present invention to provide uniform templates for the 
20 elements of each component, such as assessments, plans, for comparability and future 
expansion. 

It is yet another object of the present invention to standardize service quality 
through uniform assessments and analyses. 

It is a further object of the present invention to manage interviews through scripts, 
25 prompts and reminders. 

It is another object of the present invention to provide consent to treat and HIPAA 

requirements. 

It is a further object of the present invention to provide a clinical pathway 
approach with levels of service intensity. 
30 It is still another object of the present invention to provide a service plan based on 

consumer functional goals. 
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It is a further object of the present invention to record progress by goal and 
objective, not open unstructured narratives. 

It is another object of the present invention to report through structured records 

with consistency. 

It is a further object of the present invention to provide pre- and post- service 
assessments that have been conducted. 

It is still another object of the present invention to measure functional 

improvement. 

It is a further pbject of the present invention to provide routine periodic reports. 
These reports' may include numbers of referrals, consumers, hours, service provider, 
visits, average hours per consumer, cost per consumer, revenue per consumer, revenue 
per service provider by consumer, by hour. 

It is another object of the present invention to provide a query capability available 

to users at different levels. 

It is a further object of the present invention to serve as a reporting data 
warehouse with thirty-six rolling months of information for trend analysis and year-over- 
year reporting. 

It is yet another object of the present invention to provide the average percent 
improvement by consumer, intervention, and service provider. 

It is a further object of the present invention to determine and provide quality 
benchmarks and variances/exceptions reports. 

It is another object of the present invention to bill from the appointment and/or 
visit information as well as bill electronically for external parties equipped to receive 

electronic transmission. 

It is a further object of the present invention to provide corrective actions. 
It is still another object of the present invention to provide security, including 
limiting access to information would be restricted by service provider role and "need to 
know" in compliance with HIPAA. 

The EVRR addresses standard Triage Questions and Prompts. The EVRR. enables 
a professional service provider member to ask the individual with vision loss a series of 
standard questions, moving through a series of system actions and prompts that tngger 
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recommendations to a particular clinical pathway: i.e. mobility (safe travel) therapy, 
psychotherapy, and activities of daily living. Once the individual agrees to the 
recommendations within the various specialized areas, appointments will be made for 
further assessment, to be followed by appointments for the actual therapy if applicable. 

5 The EVRR addresses appointment and resource scheduling. The EVRR contains 

a fully accessible appointment scheduling system, including systems accessible to blind 
or partially sighted persons using speech and large print computer output. Currently, 
appointments for individuals must be scheduled on either a one-time or recurring basis. 
EVRR supports the scheduling of appointments at any location. The EVRR enables 

10 appointments to be made in a convenient manner for consumers (grouping appointments 
together on the same day, or sequencing them so as to maximize learning), as well as 
support the most efficient scheduling of service provider, equipment and facility 
resources. 

The EVRR addresses support of various payment methods. Most of the payers 
15 for services are moving to an outcomes-based payment model in which payment is made 
only upon the documented achievement of an outcome (i.e. achieving independent 
mobility within the home). Other payers and programs still reimburse on a fee-for-service 
basis, or use a voucher model, where a payer-issued voucher must be returned to the 
payer with documentation that the service was completed. Further, payers such as 
20 Medicare use electronic payment whereby billing data is transmitted via a modem 
connection. The EVRR supports all of these payment methods. 

The EVRR addresses payer fulfillment. Payer requirement fulfillment is designed 
so that outputs can easily be changed to match payer's coverage levels and documentation 
requirements. 

25 The EVRR addresses billing requirements. Most vision rehabilitation centers 

have extensive medical billing requirements. The EVRR is flexible enough to meet the 
needs of all of these sources. 

The EVRR addresses quality assurance and consumer satisfaction. The EVRR 
collects quality assurance and satisfaction data, based on both its own methodologies and 

30 industry standards. The EVRR produces various reports for managerial review, and 
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downloads for further .analysis using the program evaluation departments' statistical 
analysis software! 

The EVRR addresses reporting requirements. The EVRR enables time spent by 
service providers and other resources to be tracked for each individual for billing and 
5 reporting. 

After a consumer undergoes an initial triage and specialized assessments,, s/he is 
, classified into a specific level of care prescribed by the agency. For instance, a consumer 
with minimum needs may only require brief low vision services, while a consumer with 
complex needs may require more lengthy low vision as well as psychotherapy and/or 
10 other services. 

• The consumer profiles extend from initial clinical pathway templates that include 
an Initial Assessment (Level 0), Consumer With Minimum Restorative Needs (Level 1), 
Consumer With Moderate Restorative Needs (Level 2), and Consumer with Complex 
Restorative Needs (Level 3). However, sometimes the level of care must be changed 
15 after treatment begins. There are several reasons why such changes may be necessary. 
In these instances, the EVRR indicates this as either a variance (changed or subsequently 
undetectable of condition) or an error (clinician oversight, protocol variance, imperfect 
protocol). 

Additional advantages of the present invention will be specifically set forth by the 
20 following description as are obvious from the description and use of the present 
invention. The advantages of the present invention will be realized and attained by 
means of the elements and combinations particularly pointed out in the appended claims. 
: Therefore, the foregoing general and detailed descriptions are exemplary and explanatory 
only and should not restrict the present invention as claimed. 
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BRIEF DESCRIPTION OF DRAWINGS 

FIG. 1, is a block diagram of a customer order entry and service arrangement 
using the EVRR system from the service provider's point of view. 
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BEST MODE FOR CARRYING OtTT THE INVENTION 

The preferred embodiment of use for the innovative EVRR system will be shared 
through web technology with vision rehabilitation organizations at a minimum 
throughout the New York area as well as the United States. The preferred embodiment 
further comprises a plurality of computers connecting, by secure Internet connections, to 
a central computer. The EVRR performs program analysis, evaluation, tracking, 
standardization of care, scheduling of appointments, and coordination of billing and 
payment procedures, and reduction of administrative costs. 

SYSTEM HARDWARE AND OPERATION 



According to the invention, at least one central computer and associated system 
and stored consumer data is accessible by several other remote service provider 
15 computers. The service provider has at least two choices to use the computers and 
system. The order in which a service provider may use the computers and associated 
system when providing care to a consumer will illustrate the interaction between the 
computers and associated system. 

Considering now the remote computers in greater detail, a service provider 
20 computer includes at minimum a processor with a primary memory unit, such as a 
random access memory, a monitor with connecting video cable, a keyboard with a 
connecting keyboard cable. The remote computers may be located on desk tops of 
service providers, bedside to consumers, in nurse stations, in offices, in laboratories or 
any other location which facilitates providing care to the consumers as well as portable 
25 ("laptop") , computers. EVRR is installed onto each remote computer. The service 
provider computer must be of suitable computing speed and memory capacity. 
Additionally, the service provider computer must have an Ethernet connection or a 56K 
modem as well as a CD Rom dive. 

Considering now the interaction between the service provider and consumer in 
30 reference to the service provider remote computer and system, the service provider logs 
onto eiwer a desktop computer or portable ("laptop") computer with EVRR installed and 
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affiliated system. Data may be captured directly into the computer of the service 
provider and stored within a database of the service provider computer. 

Periodically, the service provider is required to connect to the central computer 
via Internet through Ethernet or a modem. The Internet connection enables a data 

5 exchange between the service provider computer and the central computer. The Internet 
connection to the central computer also provides other services, such as calendar updates, 
standard reporting, software updates, and other services addressed herein. 

The second choice the service provider has to use the computers and system 
comprises the service provider remote computer to always be connected to the central 

10 computer via a high speed Internet connection. A direct exchange of information 
between the service provider's computer and the central computer takes place when the 
service provider chooses to connect to the central computer in this manner. 

Considering now the central computer, the central computer comprises at least 
one server, preferably a plurality of servers, at Lighthouse in New York. The central 

15 computer is capable of servicing a plurality of remote service provider computers 
individually and selectively. The central computer and associated system store templates, 
consumer information, store and adjusts clinical pathways for data entered, store and 
adjusts care and/or training information, store and adjusts follow-up information, store 
and analyzes success rate of care and/or training given and other functions addressed 

20 herein. 

Considering now the central computer in greater detail, the central computer 
includes at minimum a processor with a primary memory unit with a connecting memory 
cable, a monitor with connecting video cable, a keyboard with a connecting keyboard 
cable. Preferably, the central computer comprises a server farm of suitable computing 

25 speed and memory capacity. The central computer is horizontally and vertically 
scaleable. The central computer provides security, including security within HIPAA 
compliance for both captured and transmitted information. Data is stored both on site in 
the Lighthouse servers as well as offsite. Additionally, data is processed in a data 
warehouse for statistical analysis. 

30 The arrangement is a hardware and software system or a hardware, software and 

internet system which facilitate communication of such information as consumer 
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information, care and treatment information, social services information and feedback 
information regarding the foregoing from the use of the system. 

SYSTEM AND SOFTWARE OPERATION 

Users of the EVRR and system will be trained to use the EVRR and system. As 
noted earlier, the arrangement is a software and hardware system that facilitates the 
communication, analysis, billing, tracking, and care of consumer data and related care 
data. Although all individual consumer or localized consumer group data and related 
care data may be used without an intranet, the preferred embodiment uses an Internet 
based intranet to make full use of all of the EVRR and system capabilities discussed 
herein. In this regard, the arrangement of the preferred embodiment may be adapted to 
be on at all times. All aspects of the isolated or semi-isolated (non-Internet) use as well 
as use comprising Internet connection, is included in the preferred embodiment, as well as 
other aspects and uses will be discussed. 

According to the. present invention, in each stage, the EVRR and system are used 
to enter consumer data and care data FIG. 1. Predetermined templates of clinical 
pathways and related pathways are accessed and updated as the data entered increases. 
Three levels, or templates for clinical pathways, exist to determine the consumer's 
restorative needs. These pathways include minimum, moderate and complex levels of 
patent need and may entail job site analysis, consumer and employer interviews, 
occupational research, informational interviews, development of a vocational goal, 
identification of educational, rehabilitation and vocational training needs, testing for 
employability skills. Calendar appointments and other information may be uploaded 
from the central computer by the service provider at any time, but for illustration 
purposes, the service provider logs onto the central computer to access the daily schedule 
1 before seeing any customers 2. 

Following an initial Registration 3 and Recording 4 of the customer, an initial 
assessment is preformed by a Social Worker, Low Vision Doctor, Low Vision Therapist 
or Assistant in order to determine the consumer's vision restorative needs to maximize 
existing vision, hi this assessment, a Comprehensive Low Vision examination, including 
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detailed history, functional assessment, and testing (including refraction), prescribing, 
dispensing and instruction in the use of low vision devices is accomplished. This entire 
assessment process is termed "Triage" 5. Two levels, or templates for clinical pathways, 
exist to determine the consumer's restorative needs for use of functional vision and may 

5 involve instruction in the use of Lorn Vision devices, a specialized evaluation and 
training for the more complex needs of the low vision, education in the use of or very 
high powered and/or specialized devices, as well as counseling, rehabilitation and further 
medical attention assessments 6. Following Triage, answers to .questions and/or data are 
saved onto the service provider's computer and the different clinical pathways and 

10 services, including such services as billing, are determined, as discussed below and 

represented as 7 in FIG. 1. 

An assessment by a Certified Social Worker with two years experience or a 
licensed Psychologist may be preformed executed to develop treatment plan for 
individual referred for psychotherapy due to vision loss resulting from disease or trauma. 
15 This may include the administration of the various testing tools, the identification of 
symptomatology for indicators of treatment, and a psychiatric evaluation to determine if 
medication or hospitalization would be appropriate. If medication is prescribed, follow- 
up psychiatric evaluation of medication will be conducted as directed by the payer. 
Individual can be re-referred for services when stabilized, and will be reassessed by a 
20 CSW or licensed Psychologist. Three levels, or templates for clinical pathways, exist to 
determine the consumer's restorative needs. These pathways include minimum, 
moderate and complex levels of patent need. The treatments may include varying 
duration and intensity of psychotherapy. 

An assessment may be preformed done by a Certified Rehabilitation Teacher, 
25 VRA or RTA in order to determine the consumer's vision restorative needs to establish a 
baseline of current functioning, needs and responsibilities of daily life skills, develop 
treatment plan maximize existing vision. Three levels, or templates for clinical 
pathways, exist to determine the consumer's restorative needs for independent living 
needs These pathways include minimum, moderate and complex levels of patent need. 
30 comprising simple instruction to intense training of such living skills as safety, self care 
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basis (personal care, eating, clock, phone, writing lists, checks, letters, BraiUe, and 
computers) or special needs such as cognitive or physical long term training. 

A Certified Orientation and Mobility Specialist may an assessment in order to 
determine assessment of skills and needs, development of goals, and development of a 
treatment plan to restore skill level lost due to vision impairment In this assessment, three 
levels, or.templates for clinical pathways, exist to determine the consumer's restorative 
needs. These pathways include minimum, moderate and complex levels of patent need 
and may involve instruction in agreed upon and needed skills to restore function. 

An assessment of skills, needs, and recommendation for equipment and training " 
assessment by a Assistive Technology Specialist or Technology Instructor may be 
preformed in order to assess present skills, access needs, system needs, and to 
recommend appropriate equipment and training, Several classifications, or templates, 
exist within determining the consumer's computer training needs. Computer instruction 
may include instruction in print enhancing programs, word processing and spreadsheet 
programs, screen reading software, keyboard layout, the Internet, and email. 

An assessment of consumer education, work history, skills and job interests may 
be preformed by an Employment Specialist in order to determine job readiness and/or 
barriers to employment for unemployed individuals, or to assess the modifications and 
accommodations necessary to enable an employed individual to remain in their job. 

These assessment results are in a defined pathway level that includes the goals, 
objectives and hours of service for a particular consumer. Hours of service are tracked 
via the Visit Record. Visits are comprised of various data elements, namely the date; 
duration, description, and payment source for each service provided. When necessary, 
the visit record may also contain a diagnosis (ICD) and treatment (CPT) code. Some or 
all of these items may be required by external entities for billing purposes. Visits should 
be recorded after each session. 

The EVRR also comprises Visit Record templates for use with various 
interventions. These forms are meant to be attached to a Incremental Record of Activity 
(herein "IRA"), so mat both the visit and goal attainment data are t6gether in one, easy to 
read document. The EVRR will deduct each visit duration from the stipulated number of 
hours for the consumers' service level, thereby tracking how much time has been used 
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and what remains. This tracking enables the service provider to gauge the consumers' 
progress and determine if the hours remaining will be sufficient to achieve all outstanding 
goals. If not, providers may request additional hours if they believe this will lead to a 
successful outcome. 

5 Once clinical pathways and level of care criteria are in place, clinical outcomes 

can begin to be collected 8. A sample of data items for low vision could include items 
addressing improvement in vision acuity and self-reported satisfaction with the ability to 
perform certain activities or for psychotherapy, sample data could include items 
addressing improvement in status and self-reported satisfaction with the ability to 

10 function in society. 

Consumer data is collected at four points in time. The first is at the assessment 
stage, addressing the consumer's experiences, difficulties in performing activities, 
interests and needs, and the like. The second is at the point when the intervention ends 
and. the provider marks all goals for which the consumer agreed to receive service, re- 
15 rates various items s/he originally rated during the assessment, and completes a 
questionnaire concerning the consumers' level of participation in the learning process. 
The consumer also re-rates each "self-assessment" item on which they originally stated 
they had a great deal of difficulty performing, and for which they received training. 
Thus, a "post-service" score is derived for comparison with the "pre-service" assessment 
20 score. The third is at the end of the Episode, addressing the consumers' assessment of. 
and satisfaction with the their services and providers. Finally, the fourth is at a point six 
months after the Episode ends, concerning the consumer's experiences during the period 
after the completion of treatment. The consumer is also asked the same "self-assessment" 
questions they originally completed during their assessment and later when they 
25 completed their training. 

In each instance where the consumer is asked to provide feedback, the surveys are 
completed independently by the consumer or with the assistance of a third party (not the 
service provider). These surveys are conducted on a random sample of individuals. 
Eventually, it may be helpful to extend certain measurement processes beyond six 
30 months in order to quantify whether any benefits are discernible over the longer term. 
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Providers will be prompted to complete a standard set of QA questions, regardless 
of the intervention or service level, when all goals for their intervention have been 
marked. However, no QA questions will be used when a consumer was assessed only 
and did not receive further service. Also, each item that was scored a 5 or below during 
5 the assessment (using the 1-10 Provider scale) is re-rated. 

The Consumer Self-Assessment Survey consists of all Assessment items in which 
consumer rated him/herself a 1 or 2 (on a scale of 1 - 4), and for which the consumer 
agreed to receive training. Thus, the Consumer Feedback is Intervention specific, but not 
Level specific. Responses will be compared with the information originally collected in 
10 the Assessment to determine if the consumer believes they have made progress and are 
more capable of performing tasks/implementing what they learned. This data can also be 
compared with the intervention outcome to learn if providers and consumers have 
different views of service delivery. These items are unique for each consumer, and each 
intervention. 

15 The Six Month Post Episode Survey consists of two components: a repetition of the 

consumer self-assessment items originally completed during the assessment process (and 
therefore intervention specific), and a more general survey. Both components are aimed at . 
identifying former consumers who may require additional services. Consumers are 
randomly selected to participate, and as with the End of Episode QA, are interviewed by a 
20 third party, not the service provider. 

Many network members possess the financial management skills to estimate costs 
per unit of service for low vision and psychotherapy. Certain members also possess the 
skills to estimate the average cost per consumer. However,, very few members can 
estimate how the cost per consumer, differs for a minimuin, moderate or complex level 
25 individual. For the following reasons, it is critically important that agencies understand 
how the cost of care differs for consumers at different intensity levels. With this in mind, 
the EVRR agencies to utilize standard cost accounting protocols in order to estimate costs 
per unit and costs per consumer for each of the intensity levels described by the clinical 
pathways. 

30 The service provider, after servicing the consumer, may either have additional 

consumers or may have serviced the final consumer ofthe day 9. From time to time or 
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after the service provider has seen and/or preformed services for customers, the service 
provider is required to connect to the central computer via Internet through Ethernet or a 
modem 10. As stated above, the Internet connection enables a data exchange between the 
service provider computer and the central computer and accomplishes such tasks as 
calendar updates, standard reporting, updates and other data manipulations. The Internet 
connection to the central computer also provides other services, such as calendar updates, 
standard reporting, software updates, and other services addressed herein. If the service 
provider connects to the central computer after servicing all customers for that day, the 
service provider has successfully completed his/her day 11. 

SYSTEM SOFTWARE OPERATION 

Starting the program will bring up the welcome menu. All records are accessed 
through the Search Menu. The first two command buttons are for users of speech 
software. Throughout the system, command buttons are placed by text messages that 
cannot be read by Jaws and other screen readers. Clicking on these will 1 repeat the text 
that is either above or to the left of the buttons. 

ENTER A NEW CONSUMER: SEARCH 

Click on the Search Menu Button or keystrokes alt e on the first screen to enter 
toe system and arrive at the search criteria screen. To be certain the consumer doesn't 
already have a case, enter the last name and select search (Alt e). To use toe Clear Screen 
key, Alt I, to blank out any information and refresh the fields. 

If a consumer is not found, a blank search result screen will appear. The search 
result consists of a header section containing the information about the selected 
consumer. The lower portion of the screen is a grid that can contain consumers) meeting 
the search criteria entered on the previous screen, such as service provider name or 
intervention. In the case of a new consumer, the grid is blank. 
Search and work with existing consumers 

Consumers can be retrieved from the main search menu by selecting from the any 
of the available fields. To work with a specific individual, type in the last name and then 
search. To retrieve those records assigned to an individual service provider member, use 
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the dropdown list to select the service provider member and then search. Similarly, 
searching can be done on a particular Intervention. For example, a search is done for all 
consumers referred to Employment. If the search results shows consumers in 
Employment, intervention code 050. The header record gives the total number of 
'5 consumers matching the search criteria and positions the record indicator on the first 
consumer, sorted in alphabetic order by last name in a grid view below the header record. 

There are three ways to retrieve records. Either use Alt N to move to the next 
consumer, the next consumer button or the mouse to click on the desired consumer. The 
VIP name fields will change to match the selection. Once the consumer is identified, use 
10 the main menu function button, Alt M, to access all records for that consumer. In this 
example, the grid row becomes bigldighted when using the mouse to select a consumer, 
the name matches the selected row, and the current consumer counter is now less than 
before. 

The simplest way to enter data in the system is to type the value in the current 
15 field and then tab to the next field. Assign an agency standard case number (the system 
will prompt if the case number already exists), as case numbers are numbers are not 
automatically generated. Throughout the system there are triggers that will either move 
the cursor to a required field, skip a section completely or automatically fill in 
information. This will happen once the user tabs past the key field. The first such trigger 
20 happens on page 1 of registration. For example, if the answer to question d, relationship 
to person that is visually impaired is self, then section e, VIP name, will auto populate. 
The cursor intentionally remains on the VIP First Name field to allow speech software to 
remain focused. 

A dropdown window is a field containing a down arrow. This indicates that there 
25 are coded values to be chosen. A blank dropdown field only allows for one choice while 
a dropdown displaying a list, such as the last two fields on the Basic Information 1 screen 
supports multiple values. 

There are several ways to select from a blank dropdown list. The simplest is to 
type the first letter or number if known. In the case of Yes/No values a y or n will 
30 populate the field. An alternate.method is to click on the down arrow using the mouse 
and the selecting the value. A third way is to use the up and down arrow keys to scroll 
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through the values. To remove an erroneous entry, tab to the field and use the backspace 
key. 

To select from a multiple value dropdown list, either use the mouse and click 
whatever values are appropriate or, arrow down the list and use the spacebar to select the 
codes. Selected codes will appear in dark blue. 

To remove an unwanted value, use the spacebar or the mouse. 
Tabbing on the last field in page one of registration will automatically turn to 
page two. Alt n is also the equivalent keystroke. Conversely, Alt p moves the cursor to a 
previous page. This can also be accomplished by using the mouse and clicking on the 
respective page headings on the top of the form. 

To complete the registration process, fill in ail demographics and enter the service 
provider of the registrar and record the registration date. Registration date is a critical 
field for the continuity of service to move the consumer into the triage phase. 

Use the save key or alt s to save the record. Every time a save is done, the system 
presents a verification that the record has been saved. To end registration, close the 
screen using the close button or Alt C. 

Throughout the system there are comment fields, which may contain instructions 
or information notes. These areas are not accessible to screen reader software. To allow 
blind workers to have access to the text, there is a button to the right of the narrative area. 
Embedded in the button is a popup window that displays the same text in an accessible 
format. Use the Esc key to clear the message. 

Once Registration has been completed and saved, the triage portion of the system 
may be worked on if the consumer is reselected from the search screen. Once registered, 
the search results screen now has the Main Menu button activated. 
Main Menu: 

The Main Menu has buttons that lead to all parts of the consumer's record. If a 
consumer has just registered, no modules are available except for Registration, Triage 
and Visual & Health Information. Until Triage is completed, the consumer entering the 
system has not started an episode of service. 
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Triage Screens: 

Triage consists of a series of seven screens designed identify problem areas, 
recommend interventions and record consumer agreement of these recommendations. In 
addition to the seven main triage screens there is also a form for entering relevant data for 
5 the federal statistical form, 7-OB. Triage questions identify problem areas using the most 
direct means of questioning. The computer will skip over questions that seem redundant 
or unnecessary. 

Intervention Recommendations: 

During triage, the computer generates the intervention recommendations. These 

10 are based upon the consumer response to status and problem identification questions. Not 
all questions have to be answered. If a recommendation for a particular intervention is 
triggered by the answer to a question, the computer has a built in skip pattern that will 
pass over the remaining questions that would trigger that intervention. The following 
example demonstrates the recommendation process. Answering "Yes" to a visual 

15 functioning problem and "Yes" to a household activities task' on Page C, triggers two 
recommendations for interventions on Page F, Recommendations, seen on the next page. 
It is assumed that the subsequent triage screens are filled in and saved- A through E. In 
order for the recommended interventions to become active in the system, the consumer 
must accept each intervention. 

20 Additional recommendations can be added manually here if other services are 

requested. Then, the triage phase must close with a close date on Page G, Filing Triage. 
Without a closure date, the intervention records will not be released and assessments 
functions will not be available. Episode Closure date is included on this screen should 
the consumer reject all services being offered. At the present time, it is also the only place 

25 to close an episode. 

Visual & health information can be entered at anytime during an episode of 
service, but it is strongly recommended that this data be entered at the beginning of the 
case, during the triage phase. It is available to workers at the beginning of each 
assessment so this information is a valuable resource. More than one of these records can 

30 exist over time and can be entered on a periodic basis. The most current record will be 
presented in the assessments. Enter, save and close this screen upon. completion. In each 
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of the assessments, a button is available to bring up the most current visual and health 
data. 

Whenever multiple records exist, there will be fields at the top of the screen to 
indicate the total number of records that exists for the consumer and the sequence of the 
5 record being viewed. In the following screen example, there are two visual and health 
records for the consumer. On the bottom of forms where multiple records can be stored, 
there are also navigation buttons for next record (Alt X) and previous record (Alt V) 
movement. 
Payers 

10 Payer information in the Prototype system is informational only. Once triage is 

completed and the consumer is re^dy for assessments, the payer button on the consumer's 
main menu becomes available. Payer information is stored by each occurrence of an 
intervention. As additional interventions are added to the consumers record during the 
service delivery phase, so to additional payer data can be added. 

15 Entering Payer: 

This is a layered screen anil is a little more involved since the desired result is to 
attach payers to interventions where there may be a . single payer with multiple 
interventions and also multiple authorization numbers. Follow these steps when entering 
a payer. * 

i0 1 . Triage must be completed, dated and saved. 

2. When on the payer screen, create a payer record by selecting new payer. (Alt W and 
enter). 

3. Fill in payer information on the top portion of the screen. Also enter the consumer ID 
and any payer contact information. 

25 4. Enter authorization information for the first intervention. You cannot save the screen 
without an authorization/intervention record. If no authorization is required, enter "none" 
in the Authorization Number field. If Interventions do not appear in the drop down list, 
then triage is not completed. Exit to the main menu, reselect triage and save it with a 
close date. 

30 5. Save the record (Alt V). 
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6. To add another authorization record with intervention to the same payer, select New 
Authorizations (Alt A). 

7. To move on to the next new payer, select new payer and continue with the same 
process. 

5 Once triage is completed, the main menu will have additional buttons activated. 

For example, Interventions and Assessments functions are available. Interventions are the 
programs that were accepted in triage. There are also additional interventions that do not 
have assessments associated with them. Viewing interventions, making referrals to non 
triage based interventions and entering visit information follows this section. 
10 There are five computerized assessments that stem from the triage 

recommendations. Assessments set the goals, objectives and levels of service for the 
consumer. On the screen,.the Interim Record of Activity button is grayed out. Only after 
at least one assessment has been completed can any progress reporting and goal 
achievement be recorded in the IRA. 
15 Enter the assessment menu by clicking on the assessment button or by using Alt 

A. All Five assessments have common computerized elements which will be discussed. 
For the specifics of each of the assessments, please reference the manual forms. 

The function keys to access the assessments are: 
AltM Mobility, 
20 Alt I Independent Living, 
AltC Computer Skills, 
Alt E Employment, 
AltS Social Service. 

Following the same design structure of registration and triage, the assessments are 
25 composed of a series of tabs, each labeled in alphabetical order. 

There are numerous dropdown boxes which do not have to be used to fill in the 
values. Numeric scores can be manually entered and it is better if tabbing and typing 
becomes the norm As in triage, narrative fields are often followed by a highlighted box 
which contains the script for speech users. Alt N and Alt P will navigate between pages. 
30 Alt S will save a form. * 



18 



{ 

Goals and Objectives are automatically generated by the system based upon the 
rating and response to the series of goal and objective questions found in each of the 
assessments. Scoring is also done by the computer based upon the consumer and 
provider ratings and will give a recommended level . of service. Before a score can be 
5 calculated, the preceding screens should be saved. 

On the screen displaying the level (different screen depending upon the 
assessment, but always found following the learning strategy and factors section), the 
provider has the opportunity to change the level of service and also record the consumer's 
agreed upon level of service. 
10 The last page of each assessment , is the service agreement page, which will 

summarize the agreed upon goals. The learning strategy and the factors that influence 
training must be completed before going to the service agreement page. The service 
agreement page contains goals that have been previously been identified. Additional 
fields are available to record any equipment or other services. Learning Strategies & 
15 Factors must be completed before goals will appear on the service agreement. Once 
completed, dated and saved, a service agreement can be printed out using either the print 
button or Alt R. The report uses whatever the default computer is on the workstation. 

Whenever a user leaves an assessment that has not been completed, the system 
will ask if the assessment is completed. Answering "No" exits the assessment. On the 
20 other hand, answering "Yes" will prompt the user to enter a file date, the completion date 
of the assessment. This is a critical point in the generation of goals and objectives. It is 
the dating and filing of the assessment that moves the goals and objectives into the IRA. 
It is an important reminder for ongoing service delivery. 
Social Service Assessment: 
25 This assessment has a unique navigation feature, based upon the social needs and 

the risk factors identified in triage. On page A of the assessment, Historical Information, 
the last field in the form is a button Assess Social Service (s). Use that button to go the 
appropriate pages that address the risk factors. Do not use the next and previous page 
buttons or alt key combinations. This will break the logical page skip pattern. By using 
30 the Access Social Service(s) button, and then either tabbing or using the next page button 
the EVRR will navigate to the appropriate pages. At first this can cause some confusion, 
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but with practice, this function will prove to be a considerable timesaver. Only use the 
next and previous page buttons when reviewing the social service assessment or if adding 
additional information not included in section 9, the triggers. 

There is a corresponding IRA for each assessment that has been completed. To 
5 access the IRA menu, navigate from the consumer main menu by either clicking on the 
IRA button or using Alt D. As other assessments are completed, their corresponding 
buttons will be activated. ■ 
The function keys to access the IRAs are: . 
Alt M" Mobility, 
10 Alt I Independent Living, 
AltC Computer Skills, 
AltE Employment, 
Alt S Social Service. 
All IRAs have the same format. 
15 1) The header section lists the consumer information, episode number, 

intervention identifier and record number. This is protected and is informational only. 

2) Progress Report Information identifies the service provider author of the report, 
in most cases, the person assigned to provide the service in the intervention, the report 
period covered and any narrative information 
20 3) Goal herniation contains a primary area for entering goal achievements and 

achievement dates and a grid view showing the goals. 

4) Objective Information contains a similar structure to goals. For the goal 
selected those corresponding objectives are displayed. 
Entering Goals and Objectives: 
25 Goals are composed of one or more objectives. Before a goal can be completed, 

all objectives should have their achievements recorded. Navigate between goals by either 
using the mouse and clicking on the selected goal or by using the functions Alt L (next 
goal) or Alt G (previous goal). The objectives will change to match the correct goal. To 
record the achievement for a particular objective, either click in the grid on the desired 
30 objective or use Alt E (next objective) or Alt 0 (previous objective). Select the 
achievement value from the dropdown list, record the achievement date and save the 
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record. You must save each objective and goal achievement individually. Use Alt S to 
save. 

Interventions equate to the programs offered by your organization and function 
similar to a record on a college transcript. Key fields in the intervention record are start 

5 date, end date, primary service^provider assigned and outcomes. Interventions generated 
by triage have the start date being the date the consumer accepted the recommendation on 
triage Tab F, Recommendations. All other fields must be entered on the Intervention 
Screen. The Intervention screen serves multiple purposes; viewing and editing, entering 
visit records, generating referrals to additional interventions and closing and recording 

1 0 the end of service report. 

Viewing and Editing Interventions: 

Select the Intervention button from the consumer main menu. If the button is 
grayed out, there are no interventions recorded for the consumer. The intervention screen 
shows one intervention per page. The heading lines show the total number of 

15 interventions in the episode, the consumer identifiers and the name of the intervention. 
Once an intervention is active, the primary service provider member should be entered on 
this screen and saved. This is a dropdown list built by the system administrator. Without 
this service provider assignment, searching and retrieving case loads by service provider 
is not possible. 

20 In order to view other interventions, use Alt N or Alt P to change to the next or 

previous intervention record. Reference the counters at the top of the screen as a guide 
when moving between interventions. The narrative block is available for entering any 
specifics about the intervention as it relates to the consumer. It is an open field that can be 
edited or added to at any time during service. 

25 Visits: 

Visits are the record of activity for the consumers in the intervention. There is a 
Visit button on the bottom of the intervention record. To enter a visit for a particular 
intervention, the intervention screen must be on. that record. In the following example, a 
visit is being entered for Independent Living ("IL"): 
30 1) Locate the record for IL, use Alt V to open the visit record, then 
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2) Enter the visit information (always check to heading information to be sure that it is 
the correct consumer in the correct intervention), and 

3) Save and Close the screen when done. 
Intervention Referrals: 

5 At any time during service delivery, additional interventions can be added to the 

consumer's record. The third button on the bottom of the intervention screen performs 
this function. 

The system will not open an intervention that is already active and will generate a 
warning. However, it does allow a second instance of an intervention that has already 
10 been completed. For example, a consumer was triaged, had mobility and was closed from 
that intervention but is now back for-more service. Another instance of mobility can be 
opened. Because mobility has an assessment associated with it, a new assessment must be 
completed. 
End of Service: 

15 When an intervention is completed and the related IRAs done, the outcome of the 

intervention and the ending date of the intervention must be entered to effectively close 
the service. The EVRR system has built in functionality to do a post service evaluation 
based upon goals and objectives in each intervention. 
End of Service Provider Report: 

20 An End of Service Report for the Intervention should be done. The provider 

should complete the fields based on the intervention provided. 
Episodes 

An episode can last a month, a year or several years. The trigger for creating 
episodes is triage. A consumer with one triage record is in Episode 1 . Upon returning and 
25 a new triage record is done, the consumer is now in episode 2. The EVRR automatically 
creates and tracks episodes. It associates all related records, assessments, interventions, 
IRAs, and similar items as addressed herein, to a specific episode number. 
Ending an Episode of Service: 

When all interventions are completed and there is no more service to be given, an 
30 episode ends. To close an episode, use triage screen G. The last field on the form is 
episode close date. Enter the date and save the record. The New Episode Button, Alt W, 
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when doing a second triage. Also Previous and Next Episode buttons will activate when 2 

or more triage records are present. 

If there are open interventions or incomplete ERAs, an error message will be 

generated when attempting to enter an episode end date. The episode cannot be 
5 completed until the error is corrected by either going into interventions and closing all 

interventions or completing the I RAs and closing the interventions. The summary field 

on the IRA must contain some information. 

Post Episode Questions and Answers: 

There are two End of Episode screens that record consumer responses to service 
10 related questions. End of Episode QA should be done once the episode has closed. The 6 

Month Post Episode QA should be completed around six months after the episode has 

. ended for the consumer. "Microsoft" "Access" can generate a list of consumers meeting 

the criteria.) 

End of Episode QA: 

15 Once an episode has closed, the end of Episode Button will be activated on the 

consumer main menu. Answer all questions and save the screen. The overall score which 

shows both pre and post service results can now be viewed for the consumer. 

All function keys use the combination of Alt plus a letter (not case sensitive). 

First press and hold down the Alt key then strike the letter. The following list displays 
20 only the letter and description, assuming alt is the prefix. 

Global Functions: 

S - Save 

C - Close 

W- New Record 
25 X- Next Record 

N-kextEage 

P - Previous Page 

E - Search 

Search Results Screen: 
30 M-MainMenu 

W - New Consumer 
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P - Previous Consumer < 
N - Next Consumer 
C- Close 

Consumer Main Menu: 
5 R - Registration 
T- Triage 
P - Payer 

-V - Visual Health 

D-IRA 
10 A - Assessments 

I - Interventions 

Q- 6 Months Post QA 

O - End of Episode OA 

E - Search 
15 C- Close 

Registration: 

N- Next Page 

P - Previous Page 

S - Save 
20 C - Close 

Triage: , 
N - New Episode 
V - Previous Episode 
X - Next Episode 
25 N - Next Page 

P - Previous Page 

S-Save 

C - Close 

Payer: 

30 P - Previous Authorization 
N - Next Authorization 
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A - New Authorization 
E - Previous Payer 
R - Next Payer 
W -New Payer 
5 S-Save 
C - Close 

Visual and Health Information 
W - New Record 
V - Previous Record 
10 X- Next Record 
S - Save Page 
C- Close Page 
Assessments: 
R - Print Agreement 
15 W - New Assessment 
X- Next Record 

V - Previous Record 

N-NextPage 

P - Previous Page 
20 S - Save 

C - Close 

Interventions: 

V- Visits 

E - End of Service Report 
25 I- - Intervention Referral 
N - Next Intervention 
P - Previous Intervention 
S - Save 
C- Close 
30 Visits: 

W- New Visit 
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N- Next Visit . 
P - Previous Visit 
S - Save 
C- Close 
5 IRA: 

X - Next Record 
V - Previous Record 
E- Next Objective 

O - Previous Objective 
10 L - Next Goal 

G - Previous Goal 

S - Save 

C- Close 

Intervention Referral: 
15 S - Save 
C - Close 

End of Service Report: 
S - Save 
C- Close 
20 End of Episode QA: 
S-Save 
C - Close 

Six Months End of Episode QA: 
S - Save 
25 C - Close 

COMPUTER CODE 
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Private Sub cmdClose_Click() 

Unload Me 
End Sub 

Private Sub cmdComputerSkills^Click ( ) 

frmCoii5>uter.Show vbModal : 
End Sub 

Private Sub cmdEmployment_Click() 

f rmEnrployment . Show vbModal 
End Sub 

Private Sub cmdIndependentIiiving_Click( ) 

f rmlLAssessirient . Show vbModal 
End Sub 

Private Sub cmdMobilityAssessment_Click() 

fnnMobility.Show vbModal 
End Sub 

Private Sub cmdSocialWork_Click() 
frmSocialWork.Show vbModal 
End Sub 

Private Sub FornLjioadO 

Dim rst As New ADODB . Recordset 

rst Open "Select: Consul Fro. Interventions Where ConsumerlD- * CustcnerlD * - And Episode- 
Episode t - And InterventionID-010. And CaseNumber = - t CaseNumber * — . cnn. _ 
adQpenForwardOnly, adLockReadOnly 

cmdSocialWork.Enabled = Ilf (rst. EOF, False, True) 

rst. Close . " 

rst Open "Select- ConsumerlD From Interventions Where Consumer^" * Customer^ * - And Episode- 

Episode * ■ And interventions -014. And CaseNumber - • - » CaseNumber *—.«».- 

adOoenForwardOnly, adLockReadOnly m * 

cmdMobilitySsessment. Enabled Ilf (rst. EOF, False, True) 

rst. Close . 
rst open "Select ConsumerlD From Interventions Where ConsumerlD- & Customer ID * - And Epxsode= 
Episode * •- " And Intervention^ • 013 • And CaseNumber - • ■ i. CaseNumber * ■ ■ - . -n. - 
adQpenForwardOnly, adLockReadOnly 
. cmdlndepende^tLiving.Enabled = Ilf (rst. EOF, False, True) . 

rst. Close • . 

rstopen -Select ConsumerlD From Interventions Where ConsumerlD- * CustomerlD * - And Ep.sode- 

Episode * - And Intervention^ ■ 050 ■ And CaseNumber . • • ■ CaseNumber t - ' - . cnn. _ 

adQpenForwardOnly, adLockReadOnly . 
cmdEmployment. Enabled - Ilf (rst. EOF, False, True) 

rst. Close ' . 

rst Open "Select ConsumerlD From Interventions Where ConsumerlD- * CustomerlD * - And Episode 
& ~ • Episode * • And intervention*,- 160- And CaseNumber - - » CaseNumber * ««», cnn. _ 

adOpenForwardOnly, adLockReadOnly 
cmdComputerSkills. Enabled = Ilf (rst.EOF, False, True) 
rst. Close 
Set rst = Nothing 
End Sub 

Private Sub Fom^Unload (Cancel As Integer) 

Set frmAssessments » Nothing 
End Sub 
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Option Explicit 
Dim Str As String 
Dim response As String 
Private rstComputer As ADODB . Recordset 
Private rst As ADODB. Recordset 
Private IsGoalsClicked As Boolean 
Public IsNewRecord As Boolean 
Public IsFileDateChecked As Boolean 

Private Sub CboAgencyServices_KeyUp < Index As Integer, KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboAgencyServices (Index) .Listlndex = -1 

End If 
End Sub 

Private Sub cboAgree_JCeyUp { Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboAgree{ Index) . I/is t Index = -1 

End If • 
End Sub 

Private Sub cboAgree Jiost Focus (Index As Integer) 

If Index = 11 Then 
If CheckForTab Then 
tabComputer . Tab = 9 
chkRecommend(2) .SetFocus 
frmComputer .Caption = "Goals 2° 
End If , 

Elself index. = 22 Then 
If CheckForTab Then* 
tabComputer. Tab =10 
chkRecommend ( 5 ) .SetFocus 
frmComputer .Caption = "Goals 3"* 
End If 

Elself Index = 35 Then 
If CheckForTab Then 
tabComputer .Tab = 11 
cmdljearning . SetFocus 

frmComputer. Caption = "Learning Strategy and Factors* 
End If 

End If . 
End Sub 

Private Sub cboAgree_Validate (index As Integer, Cancel As Boolean) 
* If consumer answers "No" to a goal then objectives are not allowed 

If Index = 0 Or Index = 1 Or Index = 2 Or Index = 3 Or Index = 4 Or Index = 5 Or Index « 6 O: 
ex = 7 Then 

If cboYesNo( 6) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 8 Or Index = 9 Or Index = 10 Or Index = 11 Then 

If cboYesNo (7) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 12 Or Index = 13 Or Index ■ 14 Then 

If cboYesNo( 8) .Listlndex <> 0 Then cboAgree (Index) -Listlndex = -1 
Elself Index = 15 Or Index = 16 Or index = 17 Then 

If cboYesNo (9) .Listlndex <> 0 Then cboAgree (Index) .Listlndex » -1 
Elself Ifidex = 18 Or Index = 19 Or Index = 20 Or Index = 21 Or Index = 22 Then 

If cboYesNo (10) .Listlndex ■<> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 23 Or Index = 24 Or Index ■ 25 Or Index - 26 Or Index » 27 Then 

If cboYesNo (11) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself index - 28 Or Index = 29 Or Index * 30 Or Index. « 31 Or Index ■ 32 Or Index = 33 Or I 
» 34 Or Index = 35 Then 

If cboYesNo (12) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
End If 
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End Sub 

Private Sub cboEnhancingName_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboEnhancingName. List Index = -1 

End If 
End Sub 

Private Sub cboEquipment_KeyUJ? ( Index As Integer, KeyCode As Integer, Shift As Integer) 
• If KeyCode = vbKeyBack Then 

cboEquipment (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboExtemalServices^KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If .KeyCode = vbKeyBack Then 

cboExternalServices (Index) .Listlndex = -1 

End If 
End Sub 

•Private Sub cboFac t or s_KeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboFactors (Index) .Listlndex « -1 
End If 

End Sub ) 

Private Sub cboKeyboardSki ll^Click ( ) 

If cboKeyboardSkill. Listlndex <> -1 Then 

If cboKeyboardSkill. Listlndex >= 0 And cboKeyboardSki 11 .List Index < 2 Then 

chkRecommend ( 0 ) .Value « 1 
End If 
End If 
End Sub 

Private Sub cboKeyboardSki ll_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboKeyboardSkill. Listlndex. « -1 

End If .\ 
End Sub 

Private Sub cboLocateKeys_Click( ) . . nH 

If (cboLocateKeys. Listlndex 0 And cboLocateKeys .Listlndex < 4) Then If Key identa 

at ion is 1-4 then recommend Goal #1 (Keyboarding) 
chkRecommend (0) .Value =* H 
End If 1 

End Sub 

\/ 

Private Sub- cboMagnifi cat ion_KeyUp( KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboMagnif icat ion. List Index = -1 

End If 
End Sub 

Private Sub cboModality_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then - 

cboModality( Index) .List Index - -1 
.End If ' 
End Sub 

Private Sub cboNotes_JCeyU& ( Index As Integer,. KeyCode ; As integer. Shift As Integer) 

If KeyCode = vbKeyBack Then 
. cboNotes( Index) .Li st Index - -1 ' 

End If 
End Sub 

Private Sub cboOperatingSystem_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboOperatingSystem. Listlndex = -1 

End If 
End Sub 
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Private Sub cboPoint Si ze_KeyUp( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboPointSize (Index) .Lis tlndex = -1 

End If 
End Sub 

Private Sub cboRateYourTyping_Click( ) 

If cboRateYourTyping. List Index <> -1 Then 

If cboRateYourTyping. Listlndex >= 0 And cboRateYourTyping. Lis tlndex < 2 Then 

chkRecommend (0) .Value = 1 
End If 
End If 
End Sub 

Private Sub cboRateYourTyping_JKeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRateYourTyping. Lis tlndex = -1 

End If ' 
End Sub 

Private Sub cboSequencing_Click( ) 

If cboSequencing. Listlndex >= 0 And cboSequencing <= 4 Then 
chkRecommend ( 0 ) .Value « 1 

End If 
End Sub 

Private Sub cboSequencing__LostFocus ( ) 

If CheckForTab Then 
cmdTestRule . SetFocus 

End If 
End Sub 

Private Sub cboServiceLevel_Click ( Index As Integer) 
If cboServiceLevel (0) .Listlndex <> -1 Then 

cboTimeFrame.Listlndex = cboServiceLevel (0) .Listlndex 
txtAssessment (27) = cboTimeFrame . Text 
End If \ 
End Sub 

Private Sub cboServiceLevel_KeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboServiceLevel ( Index) .Listlndex = -1 

End If 
End Sub 

Private Sub cboServiceLevel_LostFocus { Index As Integer) 
If cboServiceLevel (0) .Listlndex <> -1 Then 

cboTimeFrame.Listlndex = cboServiceLevel (0) .Listlndex 
txtAssessment (27 ) s cboTimeFrame . Text 
End If 
End Sub 

Private Sub cboSpeech v JCeyUp (KeyCode As Integer, Shift As integer) 

If. KeyCode » vbKeyBack Then 
cboSpeech. Lis tlndex = -1 

End .If 
End Sub 

Private Sub cboSpelling_Click() 

rf cboSpelling. Listlndex <> -1 Then 

If cboSpelling. Listlndex >= 0 And cboSpelling. Lis tlndex < 2 Then 

chkRecommend (0) .Value = 1 
End If 
End If 
End Sub 

Private Sub cboSpellingLKeyUp (KeyCode As Integer, Shift .As Integer) 
If KeyCode - vbKeyBack Then 
cboSpelling. Lis tlndex « -1 
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End If 
End Sub 

Private Sub cboSpelling_JLiOStFocus ( ) 
If CheckForTab Then 
tabComputer.Tab = 3 
cmdSpelling . Set Focus 

fnnComputer. Caption = "Standardized. Tests 1* 
End If 
End Sub 

Private Sub cboStaf f s_GotFocus ( ) 

f ntiCoraputer. Caption = "Self Assessment 1° 
End Sub 

» Private Sub cboStaf fs_JCeyUp( KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboStaf fs.Listlndex - -1 
End If 
End Sub 

Private Sub cboS t rat egy_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 
cboStrategy. List Index - -1 

End If 
End Sub 

Private Sub cboTypingSpee<5L-Click( ) 

If cboTypingSpeed.Iiistlndex = 0 Then 
chkRecommend(O) .Value « 1 
• End If 
End Sub 

Private Sub cboTypingSpeecLJCeyUp (KeyCode As integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

. cboTypingSpeed-Iiistlndex ■ -1 v-., 
End If 
End Sub 

Private Sub cboUseComputer_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode » vbKeyBack Then . . . 

cboUseComputer.Ijistlndex = -1 
End If 

End Sub 

Private Sub cboVisualFields_KeyUp( KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboVisualFields.Iiistlndex = -1 

End If 
End Sub 

Private Sub cboYesNojKeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboYesNo (Index). .Listlndex = -1 

End If 
End Sub 

Private Sub cboYesNo_LostFocus (Index As Integer) 
If Index « 4 Then 

If CheckForTab Then 

tabComputer.Tab = 2 

cboHighestEduc.SetFocus , 
frmCoraputer. Caption ** "Self Assessment 3° 
End If 
End If 

If Index = 5 Then 

If cboYesNo(5) .Listlndex =» 1 Then . 
cboKeyboardSkill . SetFocus 

End If 
End If 
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End Sub 
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Private Sub cmdAccess_Click( ) • 

MsaBox "Access Mode - Testing for font size needs with print enhancing software 0 & vbNewDxne fi 

For large print users: Use the hard copy sheet (predesigned for this test). Have consumer 2 
aloud each sentence beginning with the smallest print they feel they can see. Note the small 
size print line the consumer can read without any errors. Consumer should use his or her gl* 

s. D , vbOKOnly, "Instructions for Access Mode" 

RefreshJaws 

tabCbmputer . Tab =4 

cboPointSize ( 0 ) . SetFocus 

End Sub 

private Sub cmdClear_Click( ) 

IsNewRecord = True 
clearData cboStaffs, False 
clearData txtAssessment, True 
clearData cboVisual Fields , False 
clearData cboYesNo, True 
clearData IstDevices, False 
clearData IstOtherConditions, False 
clearData IstAf f ectTraining, False 
clearData cboUseComputer, False " 
clearData cboOperatingSystem, False 
clearData IstTypeTraining, False • 
clearData cboKeyboardSkill, False 
clearData. cboRateYourTyping , False 
clearData cboSpelling, False 
clearData cbol.ocateKeys, False 
clearData cboTypingSpeed/ False 
clearData cboPointSize, True 
clearData cboEnhancingName f False 
clearData cboMagnif ication, False 
clearData cboSpeech, False 
clearData cboModality, True ^ 
clearData cboNoteSpeedl , False 
clearData cboNoteSpeed2 , False 
clearData cboNoteAccuracyl , False 

clearData cboNoteAccuracy2 , False , 
clearData cboNotes, True 
clearData cboStrategy, False. 
clearData cboFactors, True 
clearData cboAgree, True 
. clearData cboEquipment , True 
clearData cboAgency Services , True 
clearData cboExternal Services , True 

txtAssessment (0) = Date 

txtCurrentRecord » K 
cmdSave. Enabled = True 

tabComputer.Tab « 0 . . 

End Sub 

Private Sub cmdClose_Click{ ) 

Unload Me . 
End Sub 

Private Sub cmdEDocl_Click ( ) , Awimay>t . TT , fA 

MsgBox "Perform the same test using the electronic version of the point document. Info 

e consumer that this test is being repeated to determine if there is anv ^ d "^ r ^^ e ^^ 
size needed in hard copy (reflected light) to print size needed jn electronic format <P*oje 
light}. Consumer should use his or. her glasses. », vbOKOnly, "Instructions for Electronic Do 
t 1" 

RefreshJaws ■ 
tabComputer.Tab =4 
cboPointSize (2) .SetFocus 
End Sub 
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Private Sub "cmdEDocl__LostFocus ( ) 
tabComputer.Tab = 4 
cboPointSize (2) .Set Focus 
End Sub 

private Sub cmdEDoc2„Click ( ) * . 

MsgBox "Now use the second electronic document and. perform similar observations. This aocun 
will test for print size access when there is no contextual cueing. Consumer should use his 
her glasses. 0 , vbOKOnly, " Instructions for El.ectronic Document 2* 

RefreshJaws 

tabComputer.Tab = 4 

cboPointSize (4) .SetFocus 
End Sub 

Private Sub cmdEDoc2_I*pst Focus ( ) 

tabComputer.Tab =4 

cboPointSize.{4) .SetFocus' 
End Sub 

Private Sub cmdEdoc2a_Click< ) , < 

MsgBox "(Use the computer's print size preference from this last test as your recommendata 

) « & vbNewliine & vbNewLine & — J , _ 

"RULE: If accuracy, speed, duration, and a working distance of no less tnan 

inches is maintained using a standard monitor with the standard OS settings, continue. If not 

ntroduce larger monitors, and print enhancing software.", vbOKOnly, /'Electronic Document 2 Ru. 
tabComputer.Tab =5 

cmdPrintEnhancing. SetFocus. - • ' ^ * 
frmComputer. Caption = "Print Enhancing Software" 
End Sub 

. Private Sub cmdEdoc2a_LostFocus ( ) ...... 

If checkForTab Then 
tabComputer.Tab =5 
cmdPrintEnhancing . SetFocus 

frmComputer. Caption' = "Print Enhancing Software". 
End If 
End Sub 

Private Sub cmdEyeMed_J.Click{ ) ... 

f rmEyeData . Show vbModal 

RefreshJaws 

tabComputer.Tab =0 

cmdRule . SetFocus 
End Sub 

Private Sub RefreshJaws ( ) 

tabComputer.Tab a 9 

cboYesNo (8) .SetFocus 
End Sub 

Private Sub cmdFactors_Click( ) . . vm^.* 

MsgBox "Additional Factors that influence time required for training" & vbNewLine & vbNewLine 
°-3=consumer desires minimal proficiency, +3=consumer desires high proficiency , vbOKC 
"Additional Factors" 
RefreshJaws 
tabComputerJTab =11 
cboFactors(O) .SetFocus 
End Sub 

Private Sub cmdGoal^ClickO wwo~w r 

MsgBox "Areas of recommendation instruction (Goals) -..Consumer Agreement Y.es/No" , vbOKOnly, 

s/Objective Instructions". . « 

RefreshJaws 

tabComputer.Tab = 8 

chkRecommend ( 0 ). SetFocus 

End Sub ' 

Private Sub cmdGoals_Click( ) 



Re fresh Jaws 
tabComputer.Tab = 12 ■ 
txtAssessment (14) .SetPocus 
CountGoals 

IsGoalsClicked*= False 
End Sub 

Private Sub DisplayRecommendedServices () 

Dim str2 As String 
Dim x As integer 
.x = 0 

Str = "Based on your responses, the following services would be beneficial to you:" & 
ne & vbNewLine ' 

• Goals that the consumer agreed to 

If . <cboYesNo{6) = -"Yes") Then ' Goal 

Str = Str & "Typing" & vbNewLine 
Else • 
For x = 0 To 7 

If (cboAgree(x) = "Yes") Then 

Str = Str & "Typing" & vbNewLine 
Exit For 
End If 

Next x ... 
End If • 



If (cboYesNo(7) = "Yes") Then ' Goal 

Str Str & "Use Windows /Word Processor" & vbNewLine 

Else 

For x a 8- To 11 ' Objectives. 

If cboAgree(x) * "Yes" Then 

Str = Str & "Use Windows/Word Processor" fit vbNewLine 
Exit For 
End If 
Next x ' 
End If 



If (cboYesNo(8) = ."Yes") Then ' Goal 

Str = Str & "Print Enlarging/Email" & vbNewLine 
Else • 

For x = 12 To 14 1 Objectives 

If cboAgree(x) « "Yes" Then 

Str = Str & "Print Enlarging /Email" & vbNewLine 
Exit For 
End If 
Next x 
End If 



f rmComputer - 7 
IsGoalsClicked = True 
DisplayRecommendedServices 



If (cboYesNo(9) s "Yes") Then ' Goal 

Str = Str & "Screen Reading/Email" & vbNewLine 

Else 

~ For X = 15 To 17 ' Objectives 

If cboAgree(x) ="Yes° Then 

Str = Str & "Screen Reading /Email" & vbNewLine 
'Exit For 
End If 
Next x 
End If 
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14 'I^rtH^^lnr^cina/Internet: :f vLewfine 
El3 \or x . 18 To 22 ^ ' Objectives 

If sS D S5 *? ^Infixing/Internet- « vbNetfLine 



Exit For 
End If 
Next x 
End If 



el3e por x = 23 To 27 ' Objectives 

^Stf^tr^'-ScSn'Realing/lnternet. * vbNewLine 



Exit For 
End If 
Next x 
End If 



If <c£Ves£<12>^ 

B1S %or x = 28 TO 35 ^ -Objectives 

I %^^r < ?'L;2tlvf?ecbnolo g y- * vbHe^ine 

Exit For 
End If 
Next x 
End If 

MsgBox Str. vbOKOnly.. "Goals that the consumer agreed to- 

\ 

End Sub 

private Sub CountGoalsO 
Dim i As Integer 

For i — 0 To cboAgree. Count - 1 
Select Case i 

CaS «°cS A gree(i).Text = -Yes" Then chkGoals(O) - 1 
Ca "lf 8 cbo A gree(i> -Text. = -Yes' Then chkGoaisU* • - 1 
CaS I£ 1 cboAgree(i).Text = "Yes- Then chkGoals<2> = 1 
^If^boAgreeUJ.Text =• "Yes" Then chkGoals<3> = 1 

^t*££»i» - ° Yes " Then ^ ais < 4> = 1 

• Caa !f 2 JboAg?L(i)-Text = "Yes- Then chkGoals< 5 > = 1 
CaS !f 2 cboA^ee(i>.Tex t = "Yes- Then cbkGoals(6, - 1 

End Select 
Next 
End Sub 



Private Sub cn«3Identify_ClickO. , . , eTlVi£v a WO rd, and means, other than repet 

£Sx 'Number of times ^^^tSVv^i cue^, reading the word 1. 
SStS.^'StS^.^^^SlSS I Xnstruction- 



RefreshJaws 
tabComputer . Tab * 6 



» 
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tetAssessment (12) .SetFocus 

End Sub • 

S-SSSfSBSS^^ — ch to confirm , % stoKe3 Oemc 

52a appropriate software until the consumer selects a font size and/or speech speed and tone. 
vbOKOnly. 'instructions for Keyboard Skills Testing" 
RefreshJaws 
tabComputer.Tab = 3. 
cmdKeyboardRating . SetFocus 

End Sub 

SSSSTff ^Sl^f^^^ - Keyboardihg (goal 1, . Continue assessment", ft vbNewL: 
* - a if 5 through 7 must schedule at least 20 hours in typing lab (2 hrs/day) ■ & 

NewLine & _ ^ ^ through 10 skill sufficient", vbOKOnly, "Keyboard Skills Rating" 

Ref reshJaws 
tabComputer.Tab = 3 
cboLocateKeys . SetFocus 
End. Sub 



SsSoMf .SSrSSiSS^S^ row. 5 haa moderate difficulty locating the home row, 10 ha 
o difficulty locating ^^sT ^^tt^V lo & ^^\^l „ . Continue, assessment 
vbNewLine & _. ^ ^ g fchrough ? ^ schedule at least 20 hours in typing lab (2 h 

day) - * vbNewLine ^ g ^ ^.^ guf £icient . , vbOK Only, "Key Scale and Ident 



cation Rating" 
RefreshJaws 
tabComputer.Tab = 3 
cmdTyping . SetFocus 
End Sub 



SgBox^5isuaT^a^er 9 3 C ^f u L of residual vision for -obstacle detection (dy^ and stati, 
nd to gatner/verify environmental information (orientation) needed for safe movement/ travel. 

2££' -;SuS/Tlc?uaKASiSry S iearne F - The combination of the use of -g^ion^oSUcff; 

^dyna^^^ 

r safe movement/ travel .- . vbOKOnly. -Learning Strategy Types" orotectiv e techniques", mo! 

n with communication skills to gather/verify environmental information (orientation) needed r 
afe movement/travel.-, vbOKOnly, -Learning Strategy Types nrmriocentive strate 

thodologies to gather/verify environmental information (orientation) needed for safe movement 
'S^tg^'j^SSS^S^^ralli-tloo Of tactual and proprioceptive • strategies f 

Ke rtecfion^dynamic and static, ^J^^SS^S SSSSS'JSTSSSS/SS 

ogies to gather/verify environmental information (orientation) neeGea 

• vbdKOnly, "Learning Strategy Types » 

RefreshJaws 

tabComputer.Tab = 11 

cboStrategy. SetFocus . 
End Sub 

Private Sub cmdNext_Click{ ) 

If tabComputer.Tab = 12 Then flat?om< , nt . . « vblnf ormation + vbOI 

MsgBox "You have reached the last page of the computer assessment! , vt>inrormatioii 

, "Next- Page" 
Else 

tabComputer.Tab = tabComputer.Tab + 1 
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f rmComputer .Caption 
If tabComputer . Tab = 
If- tabComputer. Tab = 
If tabComputer .Tab = 
If tabComputer. Tab = 
If tabComputer .Tab « 
If tabComputer. Tab = 
If tabComputer . Tab = 
If tabComputer. Tab = 
If tabComputer. Tab = 
If tabComputer. Tab = 
If tabComputer .Tab = 
If tabComputer .Tab = 
End If 



= tabComputer .Caption 

1 Then IstOtherConditions .SetFocus 

2 Then cboHighestEduc. SetFocus 

3 Then cmdSpel ling. SetFocus 

4 Then cmdAccess . SetFocus 

5 Then cmdPrintEnhancing. SetFocus 

6 Then cmdSpeechlns true t ion . SetFocus 

7 Then cmdNotelnstruct. SetFocus 

8 Then cmdGoal. SetFocus 

9 Then chkRecommend ( 2 ) .SetFocus 

10 Then chkRecommend ( 5 ). SetFocus 

11 Then cmdLearning. SetFocus 

12 Then txt Assessment (16) . SetFocus 



6G^.397.0'B ,Qii; 



End Sub 

Private Sub cmdNExtRecord_.Click ( ) 



With rstComputer 
.MoveNext 

If .AbsolutePosition - .RecordCount Then 
d it to form 

cmdNExt Record. Enabled = False 
cmdPreviousRecord. Enabled = True 

E?.se 

cmdPreviousRecord . Enabled .=» True 
cmdNExtRecord. Enabled = 'true 
End If 

txtCurrentRecord = .AbsolutePosition 
txtSequenceNo = ! [Assessment Sequence] 
LoadDataToControls rstComputer, cboStaffs, 



'Have record for this client and 



LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDat aToCont r ol s 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls 
LoadDataToControls 
LoadDataToCont rol s 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer , 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstCpmputer, 



rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstCpmputer, 
rstComputer , 



rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 
rstComputer, 



False 
tx tAs sessmen t , True 
cboVisualFields , False 
cboYesNo , True 
IstDevices, False 
IstOtherConditions, . False 
IstAf f ectTraining, False 
cboUseComputer, -False- 
cboOperatingSystem, False 
IstTypeTraining, False 
cboKeyboardSkill , False. 
cboRa teYourTyping , Fal se 
cboSpelling, False 
cboLocateKeys, False 
cboTypingSpeed, False 
cboP'ointSize, True 
cboEnhancingName, False 
cboMagnif ication, False 
cboSpeech, .False • • 
cboModali ty ; True 
cboNotes, True 
cboStrategy, False 
cboAgree,. True 
cbo Equipment , True 
cboAgencyServices , True 
cboExteraalServices, True 
cboServiceLevel , True 
cboFactors , True 



If ! [FinishDatfel « "12:00:00 PM" Then 

cmdSave. Enabled = True 
Else 

cmdSave . Enabled = False 
End If 
End With 



tabComputer. Tab = 0 
txtCurrentRecord. SetFocus 
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End Sub 

Private Sub cmdNotel_Click( ) • ,^ww't »ri* •* 

MsgBox Ml = errors on every step; 10 = complete accuracy on every step) & vbNewLine &Li£ 3 

less refer to Academic Skills for note takingj", vbOKOnly, "Note-taking accuracy rating 
RefreshJaws \ 
tabComputer . Tab =7 
cboNotes ( 0 ) . Set Focus 
End Sub 

Private Sub emdNote2_Click< ) , „ , , Mf i „ lec 

MsgBox Ml » no steps were complete; 10 = every step was Complete) ■ & vbNewLine & J if B 3 or xe - 

refer to Academic Skills for note taking]", vbOKOnly, -Note- taking completeness rating 

RefreshJaws 

tabComputer .Tab = 7 

cboNotes (2) .SetFocus 

End Sub 

23ff-S b -°25f!it l u^notes at all, 10 = can use notes with ease,-. vbOKOnly. "Note-taki* 

tilization° 

RefreshJaws 

tabComputer .Tab =7 

cboNotes ( 4 ) . SetFocus 

End Sub .. ... 

SsgBox^lt SSf^iS?p«~., 10 = can correctly perform tasks- * vbNewLine * vbNewLine 

-At 2nd test, ask consumer if they could think of any other way to have done this e 
cise better, if possible. If they -have an alternate method, perform the note taking test agai 
• sing that method." & vbNewLine & vbNewLine .& _ «. i 

"Rule: If the higher of the two scores is under 4, recommend Academic Skills to lea 
methods of note taking. tt , vbOKOnly., "Consumer's Rating" 
tabComputer .Tab = 8 t 
cmdGoal. SetFocus 
frmComputer. Caption - "Goals l n 
End Sub 

Private Sub cmdNote4_Los t Focus ( ) 
If CheckForTab Then 
tabComputer. Tab =8 
cmdGoal . SetFocus' 

frmComputer. Caption = "Goals 1- .... 
End If 
End Sub 

Private Sub cmdNoteInstruct_.Click{ ) " n „ >1 ~ fnnl . 

MsgBox -Note-Taking - (This test may be administered twice if the consumer chooses) , vbOKOnly 
Note Taking Ins true t ion- 
Refresh Jaws 
tabComputer . Tab f 7 

cboModality(O) .SetFocus . \ 

End Sub 

Private Sub cmdPrevious_Click ( ) 

If tabComputer. Tab = 0 Then 4>>« * vVn 

MsgBox -You are at the first page of the Computer Skills assessment!", vblnfonnation •+ vb< 

ly, "Previous Page- 
Else 

tabComputer. Tab = tabComputer . Tab - 1 

frmComputer. Caption = tabComputer .Caption 

If tabComputer. Tab = 0 Then cboStaff s . SetFocus 

If tabComputer. Tab = 1 Then Is tOtherCondit ions. SetFocus 

If tabComputer. Tab = 2 Then cboHighestEduc . SetFocus 

If tabComputer. Tab = 3 Then cmdSpelling. SetFocus 

.If tabComputer .Tab =s 4 Then cmdAccess. SetFocus. • 

If tabComputer. Tab = 5- Then cmdPr in tEnhancing. SetFocus 

If tabComputer .Tab .= 6 Then cmdSpeechlns true tion. SetFocus 
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. If tabComputer . Tab = 7 Then .cmdNotelns true t . SetFocus 
If tabComputer. Tab = 8 Then cmdGoal. SetFocus 
If tabComputer .Tab » 9 Then chkRecommend (2) .SetFocus 
If tabComputer .Tab = 10 Then chkRecommend ( 5 ) .SetFocus 
If tabComputer .Tab - 11 Then cmdLearning . SetFocus , 
End If 
End Sub 

Private Sub cmdPreviousRecordLClick ( ) ■ 

With rstComputer 
. MovePrevious 

If .AbsolutePosition = 1 Then 'Have record for this client and load it 

orm 

cmdPreviousRecord. Enabled = False 
cmdNExtRecord. Enabled = True 
Else 

cmdPreviousRecord. Enabled = True 
cmdNExtRecord . Enabled = True 
End If 

If ■ [FinishDate] ,= "12:00:00 PM" Then 

cmdSave. Enabled = True 
Else 

cmdSave. Enabled = False 
End if 

txtCurrentRecord = . Absolut ePo sit ion 
txtSequenceNo = ! [Assessment Sequence] 
LoadDataToControls rstComputer, cboStaffs, False 
LoadDataToControls rstComputer, txtAssessment , True 
LoadDataToControls rstComputer,.. cboVisualFieldS/ False 
LoadDataToControls rstComputer, cboYesNp, True 
LoadDataToControls rstComputer, IstDevices, False 
LoadDataToControls rstComputer, IstOtherConditions , False 
LoadDataToControls rstComputer, IstAf fectTraining, False 
LoadDataToControls rstComputer, cboUseComputer , False 
LoadDataToControls rstComputer, cboOperatingSystem, False 
LoadDataToControls rstComputer, IstTypeTraining, False . 
LoadDataToControls rstComputer, cboKeyboardSkill, False 
. LoadDataToControls rstComputer, cboRateYourTyping, False 
LoadDataToControls rstComputer, cboSpelling, False 
LoadDataToControls rstComputer, cboLocateKeys , False 
LoadDataToControls rstComputer, cboTypingSpeed, False 
LoadDataToControls rstComputer, cboPointSize, True 
LoadDataToControls rstComputer, cboEnhancingName, False 
LoadDataToControls rstComputer, cboMagnif ication. False 
LoadDataToControls rstComputer, cboSpeech, False* 
LoadDataToControls rstComputer, cboModality, True 
LoadDataToControls rstComputer," cboNotes, True 
LoadDataToControls rstComputer, cbc-Strategy, False 
LoadDataToControls rstComputer, cboAgree, True 
LoadDataToControls rstComputer, cboEquipment , True 
LoadDataToControls rstComputer, cboAgency Services, True 
LoadDataToControls rstComputer, cboExternal Services, True 
LoadDataToControls rstComputer, cboServiceLevel , True 
LoadDataToControls rstComputer, cboFactors, True 
End With 

tabComputer .Tab =.0 
txtCurrentRecord . SetFocus 

End Sub 



Private Sub cmdPrint_Click< ) 
Dim i As Integer 

If Printers. Count - 0 Then 

MsgBox "No printer found associating with this computer. Please add a printer to it and 
you can print out the Service Agreement!", vblnf ormation + vbOKOnly, "Printer" 
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Else ■ 

^Sen^Selecf ^Fr^^erlS^nt Where AssessmentSeguence = - ft txt Sequenced, cnn, 
aOpen^^adLoc^timistic ^ ^ . fc ^ creafce fl ngw report 

rst. Delete 
End If % - 
rst. Close 

rstTSe^Selecf VSSTSiS^SSlS Where AssessmentSeguence . - ft txtSequenceNo . cnn. 
dOpenDynamic , adLockOptimistic \ 
With rst 

If .BOF And .EOF Then 
.AddNew 

! [CaseNumber] = txtCaseNumber 
! [Episode] ■ Episode 

1 [ Assessment Sequence 1 « txtSequenceNo 
. ! [ConsumerName] a txtConsumerName 
! [AssessmentDate] = txtAssessment (0) 
! [AssessorName] = cboStaf f s .Text 

For i = 6 To 12 ' Goals 

If cboYesNo(i) .List Index = -1 Then 

. Fields (cboYesNo(i) .Tag) = 0 0 
Else 

. Fields (cboYesNo(i) .Tag) = "Yes" 
End If . 
Next 



For i = 0 To cboEquipment .Count - 1 

.Fields (cboEquipment <i) -Tag) . * cboEquipmentJi) .Text 

Next 

For i = 0 To cboAgencyServices. Count - 1 

. Fields ( cboAgencyServices ( i ) . Tag ) = cboAgencyServices < x ) . Text 

Next 

For i = 0 To cboExternalServices. Count - 1 to 
. Fields (cboExternalServices(i) .Tag) = cboExternalServxces U) .Text 



Next 

. Fields ( " TimeFrame " ) = cboTimeFrame . Text 
.Fields ("Comments") = txtAssessment (18) .Text 
.Update 
End If 
End With 

Set ComputerAgreement.DataSource = rst 

ComputerAgreement . Pr intReport 
End If 
End Sub 



S^'^tSfS^'S^ the letters with no more than ^'^J^^^^ £ 
orking distance of no less than 12 inches, continue to next phase If , more a ^ a ^2 errors, or 
a distance of less than 12 inches, or if print cannot be read at ^1. increase ^"^^ 
1 the consumer can read the print with less than 2 errors and at a distance of no less than 1 
ches. vbOKOnly; "Print Enhancing Rule l n 



Re fresh Jaws 
tabComputer .Tab = 5 
cmdPrint2 . SetFocus 
End Sub 



Private Sub cmdPrint2_Click ( ) rrr<ant-«*-r or if the c 

MsgBox -If the consumer required print to be produced at a . °* 4x ^^^f^inforcement o 
mer required more than 2 seconds to identify each letter, produce spee ch as reinforcement o 
r consideration as the primary access tool.-, vbOKOnly, -Print Enhancing Rule 2 
RefreghJaws 

tabComputer. Tab = 5 - - 

cboEnhancingName . SetFocus 
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End Sub 

ESM£ Sf^SffiTSSS^ril by the consumer, load the program Jhat ^m^cea 
enlaroe the print displayed. Load the two documents provided with this test and begin testing 
ith the size increased to 2x.)», vbOKOnly, -Print Enhancing Software" 
RefreshJaws 
tabCoinputer . Tab = 5 
cxndPrintl .SetPocus 
End Sub 

M^Bo^-irirSuKfi^gieater then 20/400 demonstrate usefulness of speech as a reinforcement 

S vision to increase reading speed and- to decrease fatigue" & vbNewUine & vbNewLxne & 

•bT If 20/400 to 20/600 include speech output and/or Braille output in evaluation as a potent^ 

^fynTS^^^rtLTIS^lit^ speech and/or Braille „ . primary .access tool (wi 

print enhancement as a potential reinforcement tool)". vbOKOnly,. "Vxsion Rules" 
RefreshJaws 
tabComputer.Tab = 0 
cboVisualFields . SetFocus 
"End Sub 

ESS*-!? y^piofe?i-rl consider an access program that can be expanded to accommodate po: 

ble further vision changes/ loss - , vbOKOnly, "Rule for Vision Loss 

RefreshJaws 

tabComputer.Tab = '0 

IstDevices . SetFocus 

End Sub # 

5S!?-Sf«2!!2f£ l Sit for work/school) skip to the 3 Keyboard Tests (Key Identif icatio 

TyJinS Speed? Combination/ Sequencing) .» . vbOKOnly. "Rule for Learning Computer" 

RefreshJaws 

tabCoinputer . Tab = 1 

cboQperatingSystem, SetFocus 

End Sub 

Private Sub cmdSave_Click( ) 

CountScore 
SaveRecdrds 

End Sub 

Private Sub SaveRecords ( ) 

Dim colComputer As New Collection 

On Error G0T0 errSave 

colComputer. Add cboStaffs ; 
colComputer .Add txtAssessment 
colComputer. Add cboVisualFields 
colComputer. Add cboYesNo 
colComputer . Add IstDevices 
colComputer. Add IstOtherConditions 
colComputer. Add IstAf f ectTraining 
colComputer. Add cboUseComputer 
colComputer . Add cboOpera tingSys tem 
colComputer. Add IstTypeTraining 
colComputer. Add cboKeyboardSkill 
colComputer. Add cboRateYourTyping 
. colComputer. Add cboSpelling* 
colComputer . Add cboLocateKeys . 
colComputer. Add cboTypingSpeed 
colComputer. Add cboSequencing 
colComputer. Add cboPointSize 
colComputer . Add cboEnhancingName 



colComputer . Add cboMagnif icat ion 
colComputer.Add cboSpeech 
colComputer.Add cboModality 
colContputer. Add cboNoteSpeedl 

colComputer.Add cboNoteSpeed2 1 

colCqmputer.Add cboNoteAccuracyl 

colComputer.Add cboNoteAccuracy2 

colComputer.Add cboNoties 

colComputer.Add cboStrategy 

colComputer.Add cboFactors 

colComputer.Add cboYesNo 

colComputer.Add cboAgree ■ 

colComputer^ Add cboEquipment 

colComputer.Add cboAgencyServices 

colComputer.Add cboExternal Services 

colComputer.Add cboServiceLevel 

colComputer.Add chkRecommend 

colComputer.Add cboHighestEduc 

Episode = txtEpisode 

If SaveDataToDB(frmCoraputer, rstComputer, colComputer, "160", False) = True Then • Save di 

to database 

MsgBox "Successfully saved the Computer Assessment!", vbOKOnly, "Save" 

If IsDate(txtAssessment (19) ) Then • Save the scores to the Interventions table 

cnn. Execute ("Update Interventions Set PreConsumerScore = • " & txt Consumer Score & _ 

■ ' , PreProviderScore = ■ " & txt Provider Score & ■ » Where ConsumerlD = 0 & Cusi 

rID & _ 

" And Agency =» 1 " & AgencyCode & n 1 And Episode = " & Episode & " And CaseNui 

= • ■ & _ 

CaseNumber & And InterventionID = '160' And (EndDate « #12:00:00 PM# or Ei 

te IS NULL) "). 

cnn. Execute ( "UPDATE ComputerAssessment AS a INNER JOIN Interventions AS b ON (a.CaseNumtK 
b, CaseNumber) ° & _ 

" AND (a. Episode w b. Episode) AND (a. ConsumerlD = b. ConsumerlD) SET a.Inte: 
tjLonSequence = b.InterventionSequence" & _ 

" WHERE b- InterventionID = '160' AND b. CaseNumber = ' ■ & CaseNumber & " ' AND 
EndDate = #12:00:00PM# OR b. EndDate IS NULL) " & _ 

" AND a . InterventionSequence = 0") 

End If 

frmComputer . Refresh 
If IsNewRecord Then 
rs tComputer . Requery 

txtSequenceNo = rstComputer ![ Assessment Sequence 3 
End If • 

f rmComputer . Refresh 
IsNewRecord « False 
Set colComputer* = Nothing 
End If 

Exit Sub 
errSave : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 
End Sub 

Private Sub' cmdSequencing_C lick {) 

MsgBox "Provider Rating (1-10 Scale)" & vbNewLine & _ 

"1 = had extreme difficulty performing sequencing task" & vbNewliine & _ 

"5 = had moderate difficulty" & vbNewLine & _ 

"10 - had no difficulties, no mistakes" & vbNewliine & _ ' 

"Rule: If 4 or less. Recommend Keyboarding" , vbOKOnly, "Sequencing Skills Scale" 
RefreshJaws 
tabComputer.Tab = 3 
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cboSequencing . SetFocus 
End Sub 

Private Sub cmdShortCut_Click( ) 

MsgBox -Press Alt P for Previous Page" & vbNewLine & "Press Alt N for Next Page" 

End Sub 

Private Sub cmdSpeech2_Click( ) 

MsgBox "1 = could not understand the speech at all" & vbNewLine & ,^ e! . aT1 .. 

9 « 5 = had moderate difficulty- & vbNewLine & <10 = had no difficulty or errors understand, 
g the speech 0 , vbOKOnly, "Speech Access Scale" 
RefreshJaws 
tabComputer 1 . Tab =6 
cboSpeech . SetFocus 
End Sub 

Private Sub cmdSpeech3_Click ( ) - , ^ u oflr j 

MsgBox "Have the consumer move through the sentences and say aloud the words that he/she ^ard. 
Assist them in repeating the words if he/she could not understand them the first tune.", vbOKOn 
, "Instructions- for Speech" 
RefreshJaws 

tabComputer. Tab =6 ■ 
cmdldentif y . SetFocus 
End Sub 

Private Sub cmdSpeechInstruction_Click( ) TA7nv 
MsgBox "Administer this test to all speech and potential speech users. Load the Letter and Wor 
Identification document provided for Speech Test One. n & „ „^ rftT , mimP 

-Demonstrate how to use the right, left, down, and then t^e up arrows Have <~ nsu ^ 
use' the arrow keys to move through letters to see if he/she can identify the letters accurately 

- vbOKOnly, "Instructions for Speech Access- , , ■ . - Kl _ , 

MsgBox "As accuracy increases, have the consumer hold the control key down and hit ^ e "^Lf 

lift arrows to hear one word at a time. Have the consumer move independently through two sent 
ces moving letter by letter and word by word. As the consumer finishes the second sentence, ac 
nstra^rtL commLd to- have the screen reader spell out a word letter by letter and characters 
ad phonically. ", vbOKOnly, "Instructions for Speech Access" 

RefreshJaws ■ 
tabComputer . Tab = 6 . 
cmdSpeech2 . SetFocus 
End Sub 

Private Sub cmdSpeechInstruction2_Click () . . 

. MsgBox "As accuracy increases, have the consumer " hold the control key ^^^^J;^,^ 6 ^ 9 ^: 
lift arrows to hear one word at a time. Have the consumer move independently through two sen 
ces moving letter by letter and word by word. As the consumer f inishes the "^/^ac^rs 
nstrate the command to have the screen reader spell out a word letter by letter and characters 
ad phonically. 0 , vbOKOnly, "Instructions for Speech Access 2" 
RefreshJaws 
tabComputer. Tab =6 
cmdSpeech2 . SetFocus 
End Sub 

Private Sub cmdSpelling_Click( ) 

MsgBox -skip if consumer wants training for personal use" & vbNewLine & _ cvni<5 
-RULE: If CBVH sponsored, consumer must score a 4. If less, recommend Academic Skills 
elling-, vbOKOnly, "Instructions for Spelling Skills" 
RefreshJaws 
tabComputer. Tab =3 
cmdSpellingRating. SetFocus 
End Sub 

private Sub cmdSpellingRanking_Click() 

MsgBox "Spelling Score (using the 1-10 Provider Scale)" & vbNewLine & _ 
°0 through 10 correct answers Score = 1" & vbNewLine & _ 
"11 through 21 correct , answers Score = 4". & vbNewLine & _ 
-22 through 34 correct answers Score = 7" & vbNewLine & - e 
°35 through 45 correct answers Score =10", vbOKOnly, "Spelling Skills Score - 

RefreshJaws 

tabComputer .Tab =3 

txtAssessment (4) .SetFocus 



Computer - 
End Sub 

2^-ri C fSSiJa??SS^l^/^ ««*Ut. a^c remediation before going on to t« 
hnolooy training^Continue ^essment-^ J-^STiSll. in concurrent academe skills class u 

imBXOVe -S'cSJ'w S^Sr^^met-mandatory spelling level for consumers sponsored by NYS CBVH i 
r ATC If less than 4. CBVH will not refer for technology assessment or training (but continue t 

complete the Readiness Eval')°. vbOKOnly, "Spelling Skills Rating" 
RefreshJaws 
tabComputer.Tab = 3 
cmdSpellingRanking.. SetFocus 
End Sub 

SgBof-Ena assessment 6 !? 1 consimer requested training for personal use", vbOKOnly, "Standardize, 
Tests Rule" 

tabComputer.Tab = 4 - 
cmdAccess . SetFocus 
End Sub 

Private Sub cmdTestRule_LostFocus ( ) 
If CheckForTab Then 

frmComputer. Caption » "Access Mode" 
tabComputer.Tab =4 
cmdAccess . SetFocus 
End If 
End Sub 

SSS^S^S^S^'pr^ Enter 3 times and rest 1 minute. Then commence typing speed 
si - have consumer type the same sentence non-stop for 3 minutes. Repeat twice, - & vbNewLine 6 
NewMne t "End assessment if consumer requested training for personal use". vbOKOnly, Instruct 
ns for Typing Speed" 
RefreshJaws 
tabComputer.Tab =3 
cmdTypingRating . SetFocus 
End Sub 

Private Sub cmdTypingRating_Click( ) 

MsgBox "1 = Types 0 - 20- words per minute. Requires keyboarding . « & vbNewLine & . 
M = Types 21 - 35 words per minute. Sufficient speed to enter any level but must practice in . 

"7 t TSes L 36 e - & 50 words per minute. Must practice in labs to increase speed if goal is office 

"^°= & Ty?es W 5irwords per minute. Sufficient speed, practice not required". vbOKOnly, -Typing 
ed Rating* 

End Sub 

Private Sub FonaJLoad ( ) 

1 Consumer Information 
* txtConsumerName.Text » FirstName & ■ " & LastName 
txtPhoneNumber = PhoneNo 

txtCaseNumber = CaseNumber / 
txtAddress = Address 
txtEpisode = Episode 

• Load all control with codes and descriptions from the database 

LoadControlsItems cboStaffs, False 

LoadControlsItems cboVisualFields, False 

LoadControlsI terns IstDevices, False 

LoadControlsItems IstOtherConditions, False 

LoadControlsItems IstAf f ectTraining, False 

LoadControlsItems cboUseComputer , False 

IioadControlsItems cboOperatingSystem, False 

LoadControlsI terns IstTypeTraining, False • 

LoadControlsI terns cboKeyboardSkill, False 
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LoadCon trol si terns 
LoadControlsItems 
LoadCon t r o 1 s 1 1 ems 
LoadControl s I terns 
LoadCon tro 1 s Items 
LoadControlsltems 
LoadCon trolsl terns 



cboRateYourTyping, False 
cboSpelling, False 
cboPointSize, True 
cboModality, True 
cboEquipment, True 
cboAgencyServices^. True 
cboExternalServices, True 



Set rst = New ADODB . Recordset 
rst .CursorLocation = adUseClient 

Set rstComputer = New ADODB . Records e t 
rstComputer .CursorLocation = adUseClient 



Create new recordset for Consumer Agreement 



Create new recordset for Computer Assessments 



rstComputer . Open 



"Select * from ComputerAssessmeht Where ConsumerlD = " & CustomerlD & „ 
n And Agency = • ■ ■ & AgencyCode & ■ ■ And Episode » ° & txtEpisode & _ 
■ And CaseNumber = 10 & CaseNumber & ° ' And Interventions * '160' 0 & _ 
- Order by AssessmentDate, FinishDate a , cnn, adOpenKeyset , adLockOptimistic 



With rstComputer 

txtRecordNo » .RecordCount 
If Not ( - EOF And . BOF) Then 
.MoveFirst 

txtCurrentRecord = . Absolut ePos it ion 
txtSequenceNo = I [Assessment Sequence] 
LoadDataToControls rstComputer, cboStaffs, False 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 



If there are assessments load the first one into the form 



txt Assessment, True 
cboVisualFields , False 
cboYesNo, True 
IstDevices , False 



LoadDataToControls rstComputer, IstOtherConditions , False 



LoadDataToControls rstComputer 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer , 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 
LoadDataToControls rstComputer, 

LoadDataToControls rstComputer, uworgmtaize, xrue 
LoadDataToControls rstComputer, cboEnhancingName, False 
LoadDataToControls rstComputer, cboMagnif ication. False 
LoadDataToControls rstComputer, ^cboSpeech, False 
LoadDataToControls rstComputer, cboModality, True 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 
LoadDataToControls rstComputer 



IstAf fectTraining, False 
cboUseCpmput er , Fal s e 
cboOperatingSystem, False 
lstTypeTraining, False 
cboKeyboardSkill , False 
cboRateYourTyping,* False 
cboSpelling , False 
cboNo t eSpeedl , Fal s e 
cboNoteSpeed2 , False 
cboNoteAc curacy 1 , Fal se 
cboNoteAccuracy2 , False •• 
cboLocateKeys, False 
cboTypingSpeed, False 
cboSequencing, False 
cboPointSize, True 



cboNotes, True 
cboStrategy, False* 
cboAgree, True . 
cboEquipment , True 
cboAgency Services , True 
cboExternalServices , True 
cboServiceLevel , True 
chkRecommend, True 
cboHighestEduc, False 
cboFactors, True 



If * RecordCount <== 1 Then 

cmdNExtRecord . Enabled . = False 
cmdPreviousRecord. Enabled = False 

Elseif .RecordCount >- 2 Then 

cmdPreviousRecord. Enabled = False 
cmdNExtRecord. Enabled » True 

End if 



txtCurrentRecord = .Absolute Posit ion 
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If ! [FinishDate) <> "12:00:00 PM" And IsDatef ! [FinishDate] ) 

cmdSave. Enabled = False 

cmdClear. Enabled = True 

cmdPrint . Enabled = T»rue 
Else 

cmdSave. Enabled = True 
cmdClear. Enabled = False 
cmdPrint.. Enabled = False 
End If 

Else - ' No ComputerAssessment records disable previous and 
cmdPreviousRecord. Enabled = False 
cmdNExtRecord. Enabled = False 

End If 
End With 

tabComputer. Tab = 0. 
End Sub 

Private Sub Form_Unload ( Cancel As Integer) . 
if rstComputer. State = adStateOpen Then 

rs tComputer. Close ■ 
End If 

Set rs tComputer = Nothing 
End Sub 

Private Sub lstDevices_LostFocus ( ) 
If CheckForTab Then 

tabComputer . Tab = 1 
IstOtherConditions.SetFocus . 
frmComputer. Caption = "Self Assessment- 2" 

End If 
End Sub 

Private Sub lstOtherConditions_Click< ) 

If lstOtherConditions.Listlndex = 7 Then 

IstAffectTraining. Enabled » False 
Else 

IstAffectTraining. Enabled = True 
End If 
End Sub . 

Private Sub 1 s to therConditions_Lost Focus ( ) • 
If CheckForTab = True Then ^_ 
If lstOtherConditions.Listlndex « 7 Then 

IstAffectTraining. Enabled = False 
Else " 

IstAffectTraining. Enabled = True 
End If 
End If 
End Sub 

private Sub tabComputer_Click(PreviousTab As Integer) 
If tabComputer. Tab = 0 Then . / 

frmComputer. Caption = "Self Assessment 1 
Elself tabComputer. Tab = 1 Then 

frmComputer. Caption = ?Self Assessment 2 
Elself tabComputer. Tab = 2 Then 

frmComputer. Caption = "Self Assessment 3 
Elself tabComputer. Tab = 3 Then 

frmComputer. Caption = "Standardized Test 1" 
Elself tabComputer. Tab = 4 Then 

frmComputer. Caption = "Access Mode 
Elself tabComputer. Tab = 5 Then 

frmComputer. Caption » "Print Enhancing Software 
Elself tabComputer. Tab = 6 Then 

frmComputer. Caption =• "Speech Access 
Elself tabComputer. Tab = 7 Then 
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frmComputer. Caption = 
Elself tabComputer.Tab = 
frmComputer. Caption = 
Elself tabComputer.Tab = 
frmComputer .Caption = 
Elself tabComputer.Tab = 
frmComputer. Caption = 
Elself tabComputer.Tab = 
frmComputer. Caption = 
Elself tabComputer.Tab = 
frmComputer. Caption = 
CountGoals 
CountScore 
End If 
End Sub 

Private Sub CountScoreO 
Dim i As integer 
Dim j As integer 
Dim tmpValue As Integer 
Dim tmpl As Integer 
Dim tmp2 As Integer 
Dim taskA As Long 
Dim taskB As Long 
Dim taskC As Long 
Dim taskD As Long 
Dim tasks As Long 
Dim OverallScore As Long 



"Note Taking" 

8 Then 
"Goals 1° 

9 Then 
"Goals 2° 

10 Then 
"Goals 3 d 

11 Then 

"Learning Strategy and Factors 0 

12 Then 

"Consumer Agreement" 



Self -Assessment 
Provider Rating 
Standardized Tests 
Learning Strategy 
Factors . 



• Required fields to calculate a score 

If ^SS™SS? r « t: J25 : "« lel^ing strategy-. vbOKOnly. "Learning Strategy" 

tabComputer.Tab =11 

cboStrategy '. SetFocus 

Exit Sub 
End If 

For i = 0 To cboFac tors. Count - 1 v 
If cboFactors(i) -Listlndex = -1 Then . 
' MsgBox {"You must select a factor rating ) 
tabComputer.Tab =11 
cboFac tors ( i ) . SetFocus 
Exit Sub 
End If 
Next 



1 Self -Assessment 
taskA = 0 

If cboKeyboardSkill. Listlndex = -1 Then - user didn't select anything default to 4 
taskA =4 

ElS taskA - cboKeyboardSkill. ItemData (cboKeyboardSkill. Listlndex) 
' End If 

If cboRateYourTyping. Listlndex = -1 Then ■ user didn't select anything default to 4 

tmpValue = 4 

ElS tmpValue = cboRateYourTyping . ItemData (cboRateYourTyping. Listlndex) 
End If 

taskA = taskA + tmpValue 

If cboSpelling.Listlndex = -1 Then - user didn't select anything default to 4 ' 

tmpValue = 4 
Else 

tmpValue = c boSpelling.ItemData(cboSpelling. Listlndex) 
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End If 

taskA - taskA + tmpValue 



1 Provider Rating 
taskB = 0! ■ 

If cboLocateKeys.Listlndex = -1 Then - Key Identification 

taskB =10 

ElS taskB = cboLocateKeys.ItemData(cboLocateKeys.Iiistlndex) 
End If 

If cboSequencing.Listlndex = -1 Then • Combination Keys « Sequencing 

tmpValue = 10 

E1S tmpValue = cboSequencing . ItemData (cboSequencing.Iiistlndex) 
End If 

taskB = taskB + tmpValue 

If cboSpeech.Listlndex = -1 Then ' Speech 'Ra ting 

tmpValue =10 

E1S tmpValue = cboSpeech. ItemData (cboSpeech.Listlndex) 
End If 

taskB = taskB + tmpValue 
' Note Taking 

If cboNoteAccuracyl-I-istlndex = -1 And cboNoteAccuracy2 .lAstlndex = -1 Then • Note-taking 1 

uracy 

tmpValue =10 \- 
* 1S If cboNoteAccuracyl.Listlndex <> -1 And cboNoteAccuracy 2. List Index <> -1 Then 'if there i 

6 2 ^1 = cboNoteAccuxacyl.It^^ \ 22 

tmp2 = c boNoteAccuracy2.ItemData(cboNoteAccuracy2.ListIndex) 

If tmpl = tmp2 Then 

tmpValue = tmpl . , . the h i g hest score from both t 

Elself tmpl >. tmp2 Then 

s 

tmpValue = tmpl 
Else 

tmpValue = tmp2 
End If 
End If 

If cboNoteAccuracyl.Listlndex <>• -i And cboNoteAccuracy 2 -List index = -1 Then ■ 1st test 

Y tmpValue = cboNoteAccuracyl .ItemData (cboNoteAccuracyl .List Index) 

End If . . 

End If 

taskB = taskB + tmpValue 

. if cboNotes<0).I.istIndex = -1 *nd cboNotesd) .Listlndex = -1 Then ' Note-taking complete™ 
tmpValue =10 

El3 h cboNotes(0>.I,i S tIndex <> -1 «« cboNotes (1) List Index <> -1 Then^ ^here were 2 te, 
tmpl = eboNotes(O) . ItemData (cboNotes(O) .Listlndex . 2nd Test 

tmp2 = cboNotes (1) . ItemData (cboNotes(l) .Listlndex) 2nd Test 

If tmpl = tmp2 Then 
tmpValue = tmpl- 
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Elself tmpl >tmp2 Then ■ take the highest score from both tes 

s 

tmpValue = tmpl 
Else 

tmpValue = tmp2 
End If 
End If 

If cboNotes(O) .Listlndex <> -1 And cboNotes(l) .Listlndex - -1 Then • 1st test only 
tmpValue = cboNotes(O) . ItemData (cboNotes (0) .Listlndex) 

End If 
End If 

taskB « taskB + tmpValue 

If cboNotes<2) .Listlndex = -1 And cboNotes<3> .Listlndex = -1 Then • Note-taking Utilization 

tmpValue = 10 

B1S If cboNotes(2>. Listlndex <> -1 And cboNotesU) Listlndex <> -1 Then > • if there were 2 test 
tmpl = cboNotes(2).Itemteta(cboNotes(2). Listing ^ ^ 

tmp2 = cboNotes{3) .ItemData (cboNotes (3) .Listlndex) Zna Test 

If tmpl = tmp2 Then 

ElS?SlV& Then '• take the highest score from both t. 

s , 
tmpValue = tmpl 

Else 

tmpValue = tmp2 
End If - 
End If 

If cboNotes (2). Listlndex <> -1 And cboNotes (3 ) .List Index = -1 Then ' 1st test only 

tmpValue = cboNotes (2) .ItemDatal cboNotes (2) .List Index) 
End If 
End If 

taskB * taskB + tmpValue 

If cboNotes (4) .Listlndex •« -1 And cboNotes (5) .Listlndex - -1 Then ■ locating steps 

tmpValue = 10 

ElS !f cboNotes<4) .Listlndex <> -1 And cboNotes ( 5 ) Listlndex <> -1 Then • if there were 2 tes 
tmpl = cboNotes (4) .ItemData (cboNotes (4) .Listlndex 1st Test 

tmp2 = cboNotes (5) .ItemData (cboNotes (5) .Listlndex) 2no Test 

If tmpl = tmp2 Then 

■iS^XlVS* Then " • take the highest score from both t 

s 

tmpValue = tmpl 
Else . 

tmpValue = tmp2 
End If 
End If . 

If cboNotes (4) .Listlndex <> -1 And cboNotes (5) .Listlndex = -1 Then ' 1st test only 
tmpValue = cboNotes (4) .ItemData (cboNotes (4) -Listlndex) 

End If 
End If 

taskB = taskB + tmpValue 

• Standardized Tests 
taskC =0 

If Not'lsNumeric(txtAssessment(4).Text) Then '.Spelling Test Score 

taskC =10 
Else 
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taskC = CLng( txtAssessment (4)) 
End If 

If cboTypingSpeed.Uistlndek- -1 Then ' Typing Speed 

tmpValue = 10 

ElS tmpValue = cboTypingSpeed . I temData < cboTypingSpeed . List Index) 
End If 

taskC = taskC + tmpValue 

If cboHoteSpeedl.Listlndex = -1 And choNoteSpeed* .Mstlndex = -1 Then ■ Note-taking speed 

tmpValue =10 

ElS If cboNoteSpeedl.Listlndex <> -1 And cboNoteS P eed2 .Listlndex <> -1 Then - if there .ere 2 1 

StS tmpl = <*™**B^ : 2nS lilt 

tn ^ 2 = cboNoteSpeed2 . I temData (cboNoteSpeed2 , Listlndex) 

If tmpl = tmp2 Then 

tmpValue = tmpl , take the highest score from both te 

Elself tmpl > tmp2 Then 

s 

tmpValue = tmpl 
Else 

tmpValue = tmp2 
End If 
End If 

' if cbo N oteSpeedl.I.i 8 tIndex <> -1 And cboNoteSpeed2 T -1 Then ■ 1st test only 
tmpValue = cboNoteSpeedl . I temData (cboNoteSpeedl .Liistlndex) 

End If 
End If 

taskC = taskC + tmpValue 

\ 

* Learning Strategy 
taskD =0 

taskD = cboStrategy.ItemData.(cboStrategy. liistlndex) 

• Factors 
taskE = 0 
tmpValue =0 

For j = 0 To cboFactors. Count - 1 i at-Tri*^ 

Select Case cboFactors ( j ) .ItemData (cboFactors (3 ) .Listlndex) 

Case -3: tmpValue = 120 

Case -2: tmpValue = 110 

Case -1: tmpValue = 105 

Case 0: tmpValue = * 91 

Case 1: tmpValue =80 

Case 2: tmpValue =60 

Case 3: tmpValue =25 

End Select 

taskE 9 taskE + tmpValue 
Next . . . 

OverallScore = ( ( (taskA * 8.3) + (taskB * 1.4) + Round((taskC * 10) - / 3) * taskD * (taskE / 4. 

5) . 
txtAssessment (16) = OverallScore 

Select Case OverallScore 

Case 0 To 40: txtAssessment (17) = "Level 5 

Case 41 To 60: txtAssessment < 17 ) = "Level 4^ 

Case 61 To 70: txtAssessment (17) = "Level 3° 
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Case 71 To 80: txtAssessment (17) = "Level 2" 
Case 81 To 90: txtAssessment (17) = "Level 1° 
' Case 91 To 100: txtAssessment (17) = n No Service Needed 0 
End Select ' 

txtAssessment (20) = CStr(taskA * 8.3) 
txtAssessment (21) = CStr(taskB * 1.4) 
txtAssessment (22) = QStr (Round{ ( taskC *■ 10) / 3)) 
txtAssessment (23) • = CStr(taskD) 
txtAssessment (24) = CStr(taskE / 4) 

txtConsumerScore = CStr(taskA * 8.3) 
txtProviderScore » CStr(taskB * 1.4) 

End Sub 

Private Sub txtAssessment_LostFocus (Index As Integer) 
Dim a As Integer 

If Index = 0 Then - 

If Not IsDate (Trim( txtAssessment (0) ) ) Then 

MsgBox "Please enter a valid assessment date!", vbOKOnly, "Assessment Date" 
txtAssessment (0) .SetFocus 
End If 
Elself Index = 9 Then 
If CheckForTab Then 
tabComputer .Tab = 6 
cmdSpeechlns truction : SetFocus 
frmComputer. Caption = "Speech Access" 
End If 
Elself Index = 14 Then 
If CheckForTab Then 
tabComputer .Tab = 7 
cmdNotelns true t . SetFocus 
frmComputer. Caption = "Note Taking" 
End If 
Elself Index = 15 Then 
CountScore 
If CheckForTab Then 
tabComputer . Tab = 12 
txtAssessment ( 16 ) . SetFocus 

frmComputer. Caption = "Consumer Agreement" 
End If t 
Elself Index = 4 Then * 
If Not IsNumeric (txtAssessment (4) .Text) Then 

MsgBox "Please enter a number for the Spelling Score". vbOKOnly "Spellxng Score 

tabComputer .Tab = 3 

txtAssessment (4 ) . SetFocus 
Else 

If (Not CLng( txtAssessment (4) ) » 1 And Not CLng (txtAssessment (4) ) = 4 And Not CLng(txtAss 
sment(4)) = 7 And Not CLng (txtAssessment (4) ) = 10) Then 

MsgBox "Please enter a 1 or 4 or 7 or 10 for the Spelling Score", vbOKOnly, "Spellxng S 

re" 

tabComputer. Tab = 3 
txtAssessment ( 4 ). SetFocus 
End If 
End If 

End If 

If Index = 19 Arid CheckForTab Then 

If Trim (txtAssessment (19) ) = "" And cmdSave . Enabled Then . • , v _ _ 

response = MsgBox ("Did you finish- the Computer Skills Assessment ?° , vbQuestxon + vbYesNc 
"File Date") . 

If response = vbYes Then 

MsgBox "Please enter the File Date ! » , vblnf ormation + vbOKOnly, "File Date 
txtAssessment (19) .SetFocus 
End If 

Elself IsDate (Trim( txtAssessment (19) ) ) And cmdSave - Enabled Then 

response = MsgBox (° Are you sure you finish the Computer Skills Assessment?". vbQuestlon •< 
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bYesNo, "File Date") 

If response = MsgBoxC -Would you like to save the Assessment information ?», vbQuestion + \ 

YesNo , "File Date") 

If response = vbYes Then 

SaveRecords 
End If 
Else 1 

txtAssessment (19) = tt ° 

End If . , 

E1S response = MsgBox(°You reached the end of the Computer Skills Assessment". vbOKOnly, ■">. 

txtAssessment (19) .SetFocus 
End If 

IsFileDateChecked = True 
End If 

End Sub 
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Option Explicit 

Private rst As ADODB . Recordset 'resordset object variable 

Private hasVision As String 

Private IsArrowKey As Integer 

Private IsShftTab As Boolean 

Public IsNewRecord As Boolean 

Private isGoalsClicked As Boolean 

Public IsFileDateChecked As Boolean 

Private IsVisuallnf oClicked As Boolean 

Private rst Employment As ADODB. Recordset » 

Dim LineCounter As Integer 

Private Sub cboAgree_Lost Focus (Index As Integer) 
If Index = 8 Then 

tabEmployment . Tab =10 

txtEmployment ( 61 ) . SetFocus 
End If 
End Sub 

Private Sub cboEmploymentStatus_Click( Index As Integer) 
If IsArrowKey > 0 Then Exit Sub 

1 If employment status 1 is employed job in/not in jeopardy then 

• employment status 2 is either employed seeking/not seeking upgrade 

• (unable to implement this rule, because other code relies answers based on status 2) 

If Index = 1 Then 

If cboEn^loymentStatus(O) .Listlndex = 3 Then chkGoals(3) .Value =* 1 

If cboEmploymentStatus (0) .Listlndex < 2 Then cboGenerallnfo (1) . SetFocus • Skip resume questi 
End If ' if employed in sta 

s 1 

End Sub 

Private Sub cboEmploymentStatus_JKeyDown (Index As Integer, .KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then . 

IsArrowKey = KeyCode 
ElseXf KeyCode «■ vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode - vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboEmploymentStatus_JCeyUp( Index As Integer, KeyCode As Integer, Shift As Integer) 

If Index = 1 Then 

If KeyCode = vbKeyBack Then 

cboEmploymentStatus (Index) -Listlndex = -1 

End If 
End If 
5nd Sub 

Private Sub cboEmploymentStatus.JLostFocus (Index As Integer) 

If Index = 1 Then 

If cboEmploymentStatus (0) .Listlndex = 3 Then chkGoals (3) -Value = 1 

If cboEmploymentStatus (0) .Listlndex < 2 Then cboGenerallnfo (1) . SetFocus ■ Skip resume quest; 
End If ' if employed in sti 

si* 

If IsArrowKey > 0 Then IsArrowKey » 0 
End Sub 

Private Sub cboFactors_KeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 



Private Sub cboFactors_Click( Index As Integer) 

If IsArrowKey > 0 Then Exit Sub 

If Index = 0 Then 

If cboFactors(O) .Listlndex <> 6 Then 

cboFactors (!) . SetFocus 
Else 

cboYesNo(lO) .SetFocus 

End If 
elself Index = 6 Then 

Call CountScore 
End If 
End Sub 

Private Sub cboFac t or s_Lost Focus (Index As Integer) 

If Index =* 0 Then 

If CheckForTab Then 

If cboFactors (0) .Listlndex <> 6 Then cboFactors (1) . SetFocus 

End If 
El self Index = 6 Then 

If CheckForTab Then Call CountScore 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboFac t or sl_KeyDown (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey * KeyCode 
Elself KeyCode = vbKeyLeft Then 
.. .IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboFac tors 1_C 1 ick ( Index As Integer) 

If IsArrowKey > 0 Then Exit Sub 

If Index = 4 Then Call CountScorel 
End Sub 

Private Sub cboFac t or sl_LostFocus (Index As Integer) 

If Index = 4 Then 

If CheckForTab Then Call CountScorel 
End If " 

.If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 



loyment - 2 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey =» KeyCode 
End If 
End Sub 



Private Sub cboGenerallnf onclick ( Index As Integer) 
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If IsArrowKey > 0 Then Exit Sub 
If Index - 0 Then 

" ffiSK" ' 2 trigger develop resume elective 
c^Goais(2) .Value = 1 ' Acquire job seeking skills 

cboYesNo (20) .Listlndex =0 
End If 

.^^fcKeneraJlnro'^.I-istlndex <> 5 Then cboGenerallnfo (3) .SetFocus 

El self Index = 8 Then 

If cboGenerallnfo ( Index) .Listlndex > -1 Then 
tabEmployment . Tab » 9 

cbo£nerallnfo(19) .Listlndex = cboGenerallnfo (Index) .Listlndex - 1 
txtEmployment (61) = cboGeneralIn£o(19) -Text 

„_ 5*. _ q Th en ' What kind of work do you do? 

""SSSK ! ?S *r= S ffiffl , -^ 5= = * Then . 
chkGoals(O) .value = 1 ' Select a vocational goal 

chkGoals(4) .Value =1 • Get a 3 ob 

End If 

^^"cboGeneraiSnroUO) .Listlndex <> 3 Then cboGenerallnfo(ll) .SetFocus 
- ElS i" cboGenerailnS UD .Listlndex <> 4 Theft txtEmployment (21) . SetFocus 
Elself Index = 12 Then 

If IsShftTab = True Then 
tabEmployment . Tab = 5 
txtEmployment (38) - SetFocus 
End If 

E1S ff £ cboG^erai 3 InfoU3, .Listlndex = 0 Or cboGenerallnfo (13) .Listlndex = 1 Then 
chkGoals (16) .Value =1 
chkGoals(2) .Value = 1. 
End If 

, ' ElS ff f cbo?enera"nSa4) .Listlndex <> 2 Then ■ cboJobDif f iculty (16, .SetFocus 

■ ElS if 'cboG^erailJo U7) .Listlndex <> 5 Then cboFactors (1) .SetFocus 

Elself Index = 18 Then ^ ■ 

If cboGenerallnfo (Index) .Listlndex > -1 Then 

tabEmployment -Tab = 9 

cmdGoals . SetFocus 

coo^enera?Info(19) .Listlndex = cboGenerallnfo. (Index) .Listlndex - 1 
txtEmployment (61) - cboGenerallnfo (19) .Text • 
End If 
End If* 
End Sub 

Private Sub cboGenerallnf o_KeyDown( Index As Integer, KeyCode As Integer. Shift As Integer, 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then - 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboGenerallnf o_*eyUp < Index As Integer. KeyCode As Integer. Shift As Integer) 

If fceyCode = vbKeyBack Then 

cboGenerallnfo (Index) .Listlndex - -l 
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End If 
End Sub 

Private Sub cboGenerallnf o^Lost Focus (Index As Integer) 

If index = 2 Then 

If CheckForTab Then 

If cboGeneralInfo(2) .Listlndex <> 5 Then cboGenerallnfo (3) .SetFocus 

End If - 
El self Index = 8 Then 

If CheckForTab Or cboGenerallnfo {Index) .Lis tlndex > -I Then 
tabEmployment . Tab = 9 
cmdGoals . SetFocus 
CountGoals 

cboGenerallnfo ( 19 ) .Listlndex a cboGenerallnfo (Index) .Lis tlndex - 1 
txtEmployment (61) « cboGenerallnfo (19) .Text 

End If ■ „ ■ 

Elself Index = 9 Then ■ What kind of work do you do? 

If CheckForTab Then 

If cboGenerallnfo (9 ) .Listlndex <> 3 Then cboGenerallnfo (10) . SetFocus 
If cboGenerallnfo (9) .List Index = 0 Or cboGenerallnfo (9) .Lis tlndex = 1 Then 
chkGoals{8) .Value = 1 ' Functional assessment inventory 

chkGoals(4) .Value = l? ' Get a job 

End If 

Elself CheckForShf tTab Then 

IsShftTab = True 

tabEmployment. Tab = 0 

txtEmployment { 8 ) . SetFocus 
End If 
Elself Index = 10 Then 

If CheckForTab Then _ „ „ 

If ' cboGenerallnfo (10) .Listlndex <> 3 Then cboGenerallnfo (11) .SetFocus 

End If 
Elself Index =11 Then 
If CheckForTab Then 

If cboGenerallnfo (11) .Listlndex <> 4 Then txtEmployment (21) .SetFocus 

End If • 
Elself Index = 12 Then 

If CheckForShf tTab Then 

IsShftTab = True • 
tabEmployment .Tab ='5 
txtEmployment (38). SetFocus 
End If 
Elself Index » 13 Then 

If CheckForTab Then *• 

If cboGenerallnfo (13) .Listlndex = 0 Or cboGenerallnfo (13) .Listlndex = 1 Then 

chkGoals(16) .Value - 1 
chkGoals(2) .Value - l 
End If 
End If 
Elself Index = 14 Then 
If CheckForTab Then 

If cboGenerallnfo (1*4) .Listlndex <> 2 Then cboJobDif f iculty ( 16) .SetFocus 

End If 
Elself Index =16 Then 
If CheckForTab Then 

If cboGenerallnfo (17) .Listlndex <> 5 Then cboFactors (1) . SetFocus 

End If 
Elself Index = 18 Then 

If CheckForTab. Or cboGenerallnfo (Index) .Listlndex > -1 Then 

tabEmployment .Tab = 9 

CountGoals . " 

cboGenerallnfo (19) .Listlndex = cboGenerallnfo (Index) .Listlndex - 1 
txtEmployment (61) = cboGenerallnfo (19) .Text 
End If 
End If 



If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 
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Private Sub cboJobDif f iculty_.Click( Index As Integer) 

If isArrowKey > 0 Then Exit Sub 

If S d cLjoiDSl?culty(Ihdex) .Listlndex = 0 Or cboJobDiff iculty ( Index) .Listlridex = 1 Then 
cboScaleRat ing ( 18 ) . SetFocus 
Else 

cboJobDiff iculty (2) .SetFocus 
End If 

tt~M I f^^3^ 1 ^ |1 ^,. Ui8tll ^ , o Or cboJobDifficulty(Index).ListIndex = 1 then 
cboYesNo(4) .SetFocus 
Else 

cboJobDiff iculty (3) .SetFocus 
End If 

E1S ?f f cSj^Dlf 3 fic!;!ty(mdex) .X,istlndex - 0 Or cboJobDiff Iculty (Index) Jistlndex =1 Tnen 
chk6oals( 13) -Value =1 ' travel skills (o&m - ^ectxve 

chkGoals(l) .Value = 1 ' complete core skills -goal 

chkRecommendation(l) .Value =1 . ' recommend o&m in dialog box 
End If 

Elself In ex . cboJobDiff iculty (Index) .Listlndex = 3 

",SSobDlfficuityT5) . L istlndex = 0 o/cboJobDiff iculty (4) ^istlndex - 1 Then 
chkGoals( 11) .Value = 1 ' improve workplace lighting - objective 

chkGoals (1) .Value = 1 • " 1 complete .^" s " 

chkRecommendation(O) .Value = 1 • recommend IL in dialog box 

End If 

El l"cbo1obDlfficu??y(Index).I.i S tIndex = 0 Or cboJobDiff iculty (Index) -Jistlndex = 1 Then 
chkGoals (12) .Value = 1 1 organizational skills (lb) - ob 3 ective 

chkGoalsU) .Value = 1 ' complete core skills - goal 

chkRecommendation(O) .Value = 1 '. recommend II> m dialog box 
End If 

' ElS If^o^obDlf f icu?ty(Index) .Listlnde* « 0 Or cboJobDiff iculty (Index) .Listlndex = 1 Then 
chkRecommendation(O) .Value = 1 ' recommend IL in dialog box 
If hasVisiOn = n l" Then ■ ' consumer has no vision 

chkRecommendation(3) .Value = 1 ' recommend LV in dialog box 

ElS chkRecommendation(2).Value = 1 • recommend computer skills in dialog box 

End If ' 
End If 

ElSeI ^ £ n cSjobDif5!culty(Index).ListIndex = 0 Or cboJobDiff iculty (Index) .Listlndex = 1 Then 
chkRecommendation'(2) .Value = 1 
End If 
Elself Index = 8 Then 
tabEmployment -Tab = 3 

E1S ?f f cboJo^:fficu!ty(lndex).bistIndex = 0 Or cboJobDiff iculty(Index) .bistlndex = 1 Then 
chkRecommendation(O) .Value = 1 
cboScaleRat ing ( 0 ) . SetFocus 
Else 

cboJobDifficulty (10) .SetFocus 
End If 

ElS S f cboJobDlffJcSS(lndex) .Histlndex = 0 Or cboJobDiff iculty ( Index) .Listlndex = 1 Then 
chkRecommendation(O) .Value =1 ( , , .... 

chkGoals ( 12 ) .Value =1 ' organizational fkXllB 

chkGoals (1) -Value = 1 ' complete core skills 

ElS S^S?obDlfiicSt^ = 0 Or cboJobDifficulty(Index).I.istIndex * 1 Then 

chkRecommendation(l) -Value =1 

chkGoals (13) .Value = 1 1 travel skills (O&M) 

. chkGoals (1) .Value = 1 ' complete core skills 

cboScaleRating (2) .SetFocus 
Else 
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cboJobDifficulty( 11) -SetFocus 
End If 

E1S S f c^ob D Iffi^S(Index) .Listlndex = 0 Or cboJobDif ficulty (Index) .Listlndex = 1 Then 
cboScaleRa t ing ( 3 ) . SetFocus 
Else. 

cbo JobDi f f iculty ( 13 ) . SetFocus 
End If 

ElS If^oo5obDiffLSS(Index) .Listlndex = 0 Or cboJobDif ficulty (Index) listlndex = i Then . 
cboScaleRating (7) .SetFocus 
Else 

tabEngployment . Tab = 7 
cboJobDifficulty(14) .SetFocus 

End If 

E1S lJ^boJobDl«LSty (index, .Listlndex - 0 Or cboJobDif ficulty (Index) .Listlndex = 1 Then 
cboScaleRating (11) .SetFocus 
Else 

cboJobDif ficulty ( 15 ). SetFocus 
End If 

E1S !"cboJo^Dlff?culS(lndex, .Listlndex = 0 Or cboJobDif ficulty (Index) .Listlndex = 1 Then 
cboGeneralinf o ( 14 ) - SetFocus 

ElS cboJobDifficulty(16) .SetFocus 

End If 
End If 
End Sub 

Private Sub cboJobDif f iculty_KeyDown( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey » KeyCode 
Elself KeyCode = vbKeyDown Then ( < 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode x 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboJobDif f iculty_KeyUp ( Index As Integer. KeyCode As Integer, Shift As Integer) 

.If KeyCode = vbKeyBack Then 

cboJobDif ficulty (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboJobDif ficultyJLost Focus (Index As Integer) 

If index = 1 Then - . 

" S e cnSSSfS"lty(Index) .Listlndex = 0 Or cboJobDif ficulty (Index) .Listlndex = 1 Then 
cboScaleRating ( 18 ) . SetFocus 
Else . 
cboJobDif ficulty (2) .SetFocus 

End If ' 
End If 
Elself Index = 2 Then 

" ^cSSSfScultydndex, .Listlndex - 0 Or cboJobDif ficulty (Index) .Listlndex = 1 Then 
cboYesNo ( 4 ) . SetFocus .... 
Else 

cboJobDif ficulty (3) .SetFocus 
End If . 
End If 
Elself Index = 3 Then 
If CheckForTab Then 
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If cboJobDifficulty (Index) .Lis tlndex = 0 Or cboJobDif f iculty ( Index) .List Index = 1 Then 
. chkGoals( 13) .Value = 1 
chkGoals(l) .Value = 1 
chkRecommendation (1) .Value = 1 
End If 
End If 
El self Index = 4 Then 
If CheckForTab Then 

If hasVision = "1° Then cboJobDiff iculty (Index) .Listlndex = -1 

If cboJobDif f iculty (Index) .Listlndex a 0 Or cboJobDiff iculty (Index) .Lis tlndex = 1 Then 
chkGoals (12) .Value = 1 
chkGoals(l) .Value = 1 
chkRecommendation (0) .Value = 1 
End If 
End If 
El self Index = 5 Then 
If CheckForTab Then 

If cboJobDiff iculty ( Index) .Listlndex = 0 Or cboJobDif f iculty (Index) .Lis tlndex = 1 Then 
chkGoals (12) .Value = 1 
chkGoals (1) .Value =» 1 

chkRecommendation (0) .Value = 1 • 
End If 
End If 
El self Index = 6 Then 
If CheckForTab Then 

If cboJobDifficulty( Index) .Listlndex = 0 Or cboJobDif f iculty (Index) .Listlndex = 1 Then 
chkRecommendation(O) .Value = 1 • recommend IL in dialog box 
If hasVision = n l" Then ■ consumer, has no vision 

chkRecommendation(3) .Value = 1 ' recommend LV in dialog box 
Else 

chkRecommendation (2) .Value = 1 1 recommend computer skills in dialog box 
End If 
End If 
End If 
Elself Index = 7 Then 
If CheckForTab Then 

If CboJobDif f iculty ( Index) .Listlndex = 0 Or cboJobDif f iculty (Index) .Listlndex = 1 Then 

chkRecommendation ( 3 ) .Value = 1 
End If 
End If 
Elself Index « 8 Then 
If CheckForTab Then 

tabEmployment . Tab = 3 
cboRating(O) .SetFocus 
End If 
Elself Index = 9 Then 
If CheckForTab Then 

If CboJobDiff iculty (Index) .Listlndex = 0 Or cboJobDif f iculty (Index) .Listlndex = 1 .Then 

chkRecommendation (0) .Value = 1 

cboScaleRating(O) .SetFocus 
Else 

cboJobDxfficulty (10) .SetFocus 
End If 
End l£ 
Elself Index = 10 Then 
If CheckForTab Then 

If cboJobDifficulty (Index) .Listlndex = 6 Or cboJobDif f iculty (Index) .Listlndex = 1 Then 
chkRecommendation ( 0 ) . Value - 1 
chkGoals (12) .Value = 1 

chkGoals (1) .Value = 1 ' complete goal skills 

End If 
End If 
Elself Index = 11 Then 
If CheckForTab Then 

If cboJobDifficulty(Index) .Listlndex = 0 Or cboJobDifficulty (Index) .Listlndex = 1 Then 
chkRecommendation (1) .Value =1 

chkGoals (13) .Value = 1 ' travel skills (O&M) 

chkGoals (1) .Value = 1 ' complete core skills 

cboScaleRat ing ( 2 ) SetFocus 
Else 
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cboJobDifficulty (12) .SetFocus 
End If 
End If 
Elself index = 12 Then 

" ifcSSSf^lty(Index) .Listlndex = 0 Or cboJobDifficulty (Index) .Listlndex = 1 Then 
cboScaleRat ing ( 3 ) . SetFocus 
Else 

. cboJobDifficulty (13) .SetFocus 

End If 
End If • 
Elself Index - 13 Then 

" S e ^SD?fScSlty(Index,.I,ist I ndex = 0 Or cboJobDifficulty (Index) listlndex = 1 Then 
cboScaleRat ing (7) .SetFocus 
Else 

tabEmployment.Tab = 7 

cboJobDiff iculty ( 14 ). SetFocus 
r End If 

End If 

ElS If f c£?obDrfftcSS(Index, listlndex = 0 Or cboJobDifficulty (Index) .Listlndex = 1 Then 

cboScaleRating(ll) .SetFocus 

Else ' * 

cboJobDifficulty (15) .SetFocus 

End If 
Elself index » 15 Then 

" S e IwSSmculty(Inde X ) . Listlndex . 0 Or cboJobDifficulty (Index) .Listlndex = 1 Then 
cboGenerallnfo ( 14 ). SetFocus 

E1S cboJobDifficulty(16) .SetFocus 
End If 
End If 
End If 

If isArrowKey > 0 Then isArrowKey =0 
End Sub \ 

private Sub cboRating_Click ( Index As Integer) 

If index = 0 Then ' rate the consumer's presentation 

If cboRating( Index) .Listlndex <- 4 Then .. r , iv . 

chkGoals(lO) .value = 1 grooming (IL) o^ectxve 

chkGoals(l) .value = 1 • complete cor e skills 

chkRecommendation(O) .Value = 1 • recommend IL xn dialog box 

Else?* index - 1 Then ' rate the . consumer ability to move around the workplace 

" SSSfflJSWi 1 ?? - " <= 4 ^ traV ietfcorl skffis 
■ .cn^co^aafion<l,!value = l • iS^Sd mobility in dialog box 

Elself^ndex = 2 Then • ' rate the adequacy of workplace lighting to meet consum 

■ s needs . , . 

If cboRating( Index) .Listlndex <= 4 Then 

chkRecommendation(l) .Value = 1 • Mobility 

chkGoalsUl) .Value = 1 1 Workplace L ig hting 

chkGoals(l) .Value - 1 ' complete core skills 

Elself^nd" - 3 Then ' rate the consumer's ability to locate items in his/her 

rkspace " . m _ 

If cboRating( index) .Listlndex <=* 4 Then 

chkRecommehdation(O) -Value = 1 "Hi m nal .-Mils fT L ) 

chkGoals (12). Value = 1 "^I^J^.iXa 
chkGoals(l) .Value = 1 ' complete core sills 

End If . 

El8 If f cbo^ingtlndex) .Listlndex- <= 4 Then chkRecommendation ( 2 ) .Value = 1 
Elself Index = 5 Then 
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Xf cboRating { Index) .Listlndex <= 4 Then c hkRecommendation(2) .Value = 1 
Elself Index >= 8 And Index <= 11 Then 

If cboRating (Index*) .Listlndex <= 4 Then 

chkGoals (2) .Value = 1 1 Acquire 30b seeking skills 

■ chkGoals (15) .Value = 1 1 Complete job interview training 

End If 
Elself index = 13 Then 

If cboRating (index) .Listlndex <= 4 Then 

chkRecommendation(O) .Value = 1 1 IL recommendation 

chkGoals(l) .Value = 1 1 Complete core skills 

chkGoals( 10) .Value - 1 ' Grooming (ID 

End If 
Elself Index =15 Then 

If cboRating ( Index) .Listlndex 8 Then ■ 
chkGoals(2) .Value = 1 ' Acquire job seeking skills 

chkGoals( 14) .Value = 1 1 Develop a resume 

End If 

End If 
End Sub 

Private Sub cboRating_KeyUfc> (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRating (index) .Listlndex = -1 
End If 
End Sub 

t 

Private Sub cboRating_LostFocus (Index As integer) 

Xf Index - 0 Then 1 rate the consumer's presentation 

If cboRating (index) .Listlndex <= 4 Then 

chkGoals (10) .Value - 1 * grooming (IL) objective 

chkGoals(l) .Value = 1 1 complete core skills 

chkRecommendatioh(O) .Value « 1 1 recommend IL in dialog box 

ElsScf index = 1 Then ' rate the consumer ability to move around the workplace 

If Not CheckForShftTab Then 

If cboRating (Index) .Listlndex <* 4 Then 

chkGoals (13) .Value =1 1 travel skills (o&m) 

• chkGoals (1) -Value = 1 * complete core skills. 

chkRecommendation (1) .Value = 1 . 1 recommend mobility in dialog box 
End If 

ElsSf index = 2 Then ' rate the adequacy of workplace lighting to meet consul 

s needs 

If Not CheckForShftTab Then 

If cboRating (Index) .Listlndex <= 4 Then 

chkRecommendation(l) .Value = 1 1 Mobility 

chkGoals (11) .Value =1 » Workplace Lighting 

chkGoals (1) .Value => 1 ' complete core skills 

End If 

Elself index = 3 Then ' rate the consumer's ability to locate items in his/he 

rkspace 

If Not CheckForShftTab Then 

If cboRating (index) .Listlndex <= 4 Then 
chkRecommendation(O) .Value = 1 1 TI* 

chkGoals (12) .Value =1 ' organizational skills (IL) 

chkGoals (1) .Value = 1 . ' complete core sills 

End If. 
End If 

?IS S^ot d ^ Then If cboRating (index) .Listlndex 4 Then chkRecommendation < 2 ) .\ 

= 1 

ElS If f Not d ^ Then If cboRating(Index) .Listlndex <= 4 Then chkRecommendation (2 ) .\ 

= 1 

Elself index >= 8 And Index <= 11 Then 
If Not CheckForShftTab Then 
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If cboRating( Index) .Listlndex <= 4 Then ' 
chkGoals (2) .Value =1 • Acquire job seeking skills 

chkGoals (15) .Value = 1 1 Complete job interview training 

End If 
End If 
Elself Index = 13 Then 

If Not CheckForShftTab Then 

If cboRating't Index) .Listlndex <= 4 Then 

chkRecommendation(O) -Value = 1 • IL recommendation 

chkGoals (1) .Value = 1 1 Complete core skills 

chkGoals (10) .Value = 1. ' Grooming (IL) 

End If 
End If 
Elself Index ■ 15 Then 
If CheckForTab Then 

tabEmployment . Tab = 8 
cmdLearn2 . SetFocus 

If cboRating (Index) .Listlndex <= 8 Then 
chkGoals (2) .Value = 1 1 Acquire 3 ob seeking skills 

chkGoals (14) .Value = 1 ' Develop a resume 

End If 
End If 
End If 

End Sub 

Private Sub cboScaleRating_C lick (Index As Integer) 

If if d cboScaleRating(0) .Listolndex = 0 Or cboScaleRating (0) .Listlndex - 1 Then 
chkGoals (10) .Value = 1 1 recommend grooming (IL) . 
chkGoals (1) .Value = 1 
chkRecommendation(O) .Value = 1 
End If 
Elself Index = 1 Then 

If cboScaleRating (1) .Listlndex = 0 Or cboScaleRating (1) .Listlndex = 1 Then 
chkGoals (10) .Value = 1 1 recommend grooming (IL) 
chkGoals (1) .Value = 1 
End If 
Elself Index - 10 Then 

tabEmployment ."Tab = 7 
Elself Index = 18 Or Index = 17 Then 

If cboScaleRating (Index) = 0 Or cboScaleRating ( Index) =.1 Then 
chkGoals (10) .Value = 1 ' recommend grooming (IL) 

chkRecommendation(O) .Value « 1 1 recommend IL in dialog box 
End If * ' 

End If 
End Sub 

Private Sub cboScaleRating _JCeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboScaleRating (Index) .Listlndex - -1 

End If 
End Sub 

Private Sub cboScaleRating^LostFocus (Index As Integer) 
If index = 0 Or Index = 1 Then 

If I^c^ScIleR^ting (Index) .Listlndex = 0 Or cboScaleRating (Index) .Listlndex = 1 Then 
chkGoals (10) .Value = 0 1 grooming (IL) 

chkGoals (1) .Value = 1 ' complete goal skills 

chkRecommendation(O) .Value = 1 
End If 

End If . 
Elself Index = 10 Then 

If CheckForTab Then tabEmployment .Tab =7 
Elself Index = 18 Or Index- = 17 Then 

If CheckForTab Then 
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0 Or cboScaleRa ting (Index) .'List Index = 1 Then chkGo 



Private Sub. cboStaf f s_JKeyUp( KeyCode As Integer, Shift As Integer) 

If KeyCode = vfcKeyBack Then 
cboStaf fs. Listlndex = -1 
' End If 
fend Sub 

Private Sub cboYesNo_C lick (Index As Integer) 

If IsArrowKey > 0 Then Exit Sub 

If Index =s 0 Then 

If cboYesNq(O) .Listlndex <> 0 Then cboGenerallnf o ( 2 ) . SetFocus 
El self Index = 3 Then 

If (cboYesNo (1) .Listlndex = 0 Or cboYesNo (2) .List Index = 0 Or _ 
cboYesNo (3) .Listlndex = 0) Then cboGenerallnfo (5) -SetFocus 
Elself Index = 5 Then 

If cboYesNo (Index) .Listlndex = 1 Then 

chkGoals (13) .Value =1 1 recommend travel skills (O&M) 

chkRecommendation(l) .Value = 1 * recommend O&M in dialog box 
End If ! 
Elself Index = 7 Then 

If cboYesNo (Index) .Listlndex = 1 Then 

chkGoals (15) .Value = 1 1 complete job interview training 

chkGoals (2) .Value = 1 1 acquire jpb seeking skills 

cboJobDifficulty(lO) .SetFocus . . 
End If 
End If 
End Sub 

Private Sub cboYesNo__KeyDown { Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then ' 

. IsArrowKey = KeyCode 
Elself KeyCode = .vbKeyDown Then 

IsArrowKey '= KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLef t Then 

IsArrowKey = KeyCode- 
End If 
End Sub 

Private Sub cboYesNo_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboYesNo (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboYesNo_LostFociis (Index As Integer) 

If Index « 0 Then 

If cboYesNo (0) .Listlndex <> 0 And CheckForTab Then 

cboGenerallnfo (2) .SetFocus 
End If 
Elself Index = 3 Then 
If CheckForTab Then 

If (cboYesNo(l) .Listlndex = 0 Or cboYesNo (2) -Listlndex » 0 Or" _ 
cboYesNo (3) -Listlndex = 0) Then cboGenerallnfo (5) . SetFocus 

End If 
Elself Index = 5 Then 

If cboYesNo (Index) .Text « "No • Then 
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If cboScaleRating (Index) .Listlndex* = 
(10) :Value = 1 

End If 
End If 
End Sub 
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chkGoals (10) .Value =1 

chkRecommendation(l) .Value = 1 
End If 
Elself Index = 7 Then 

If cboYesNo ( Index) .Listlndex « 1 Then ( 

chkGoals (15) .Value = 1 ' Complete job interview training 

chkGoals (2) .Value =1 

cboJobDifficulty(lO) .SetFocus 

End If . 
Elself Index =25 Then 

If cboYesNo (Index) .Lis tlndex = 1 Then cboJobDiff iculty (6) .List Index = 3 

Elself Index = 26 Then 

If cboYesNo( Index) .Listlndex * 1 Then cboJobDiff iculty (7) .List Index = 3 

End If 

If IsArrowKey > 0 Then IsArrowkey =0 
End Sub 

Private Sub cmdBenef itNote_Click( ) , ^ _ n ™ c 

MsgBox "If any. entitlements are choses. discuss Impact of Employment on Entitlements with Bene 
s", vbOKOnly, "Benefit Instructions' 1 
tend Sub 

Private Sub cmdClear_Click ( ) 

IsNewRecord = True 

clearData txtEmployment , True 

clearData cboStaffs, False - 

clearData cboGenerallnf o , True 

clearData chkGoals , True 

clearData cboYesNo, True 
■ clearData cboJobDiff iculty, True 

clearData IstEmployment , True 

clearData cboFactors, True 
• clearData cboFactorsl, True 

clearData IstEmployment, True 

If Not rstEmployment.BOF Then rstEmployment .MoveFirst 

txtCurrentRecord » ■ ■ 

cmdPr int. Enabled = False 

cmdSave. Enabled = True 

tabEmployment .Tab = 0 

End Sub 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdEyeData__.Click() 

IsVisuallnfoClicked = True 

f rmEyeData . Show vbModal 
End Sub 

Private Sub cmdinstruct_Click( ) . ■ m .-^^ r 

MsgBox ?If the answer to any consumer self -rating question is a 1 or 2: recommend training 
the consumer does not answer or indicates he/she is not interested in the task, mark as R rc 
d", vbOKOnly, "Self Assessment Instruction" 
End Sub 

Private Sub cmdLearn2_Click () „ ww ^ fl c 

MsgBox "Visual Learner" & vbNewLine & "Visual /Tactual /Auditory Learner" & vbNewLine & 

"Tactual /Auditory Learner- & vbNewLine & "Visual /Tactual Learner" & vbNewLine & _ 
"Tactual Learner/Traveler", vbOKOnly, "Learning Strategy Types" 

tabEmployment .Tab = 7 

tabEmployment .Tab = 8 

cboGenerallnf o( 15) .SetFocus 

End Sub 

Private Sub cmdLearning_Click ( ) „ _ p „v Mat , T : no 

MsgBox "Visual Learner" & vbNewLine & "Visual /Tactual /Auditory Learner" & vbNewLine & _. 
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"Tactual/Auditory Learner 0 & vbNewLine & "Visual /Tactual Learner" & vbNewLinefc _ 
"Tactual Learner /Traveler 0 , vbOKOnly, "Learning Strategy Types" 
t abEmp 1 oymen t . Tab = 2 

t abEmpl oymen t . Tab = 3 * 
cboGenerallnfof 6) .SetFocus - 
End Sub 

Private Sub cmdNext_Click ( ) 

If tabEmployment . Tab « 10 Then • 

MsgBox "This is the last page of the Employment Services. Assessment 0 , vblnformation + vdokc 
, "Next Page" 
Else 

tabEmployment . Tab = tabEmployment .Tab + 1 
f rmEmployment - Caption = getTabCaption ( tabEmployment .Tab) 
End If 
End Sub 

Private Sub cmdNExtRecorcL.Click<) 

With rstEmployment - 

. MoveNext 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord. Enabled = False 

cmdNExtRecord . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord . Enabled = True 

cmdNExt Record. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True / 

cmdNExtRecord. Enabled » False 
End If 

txtCurrentRecord = -AbsolutePosition 
■ LoadDataToControls rstEmployment, cboEmploymentStatus , True 
LoadDataToControls rstEmployment, txtEmployment , True 
LoadDataToControls rstEmployment, cboStaffs, False 
LoadDataToControls rstEmployment, cboGenerallnf o , True 
LoadDataToControls rstEmployment, chkGoals, True 
LoadDataToControls rstEmployment, cboYesNo, True 
LoadDataToControls rstEmployment, cboJobDif f iculty. True 
LoadDataToControls rstEmployment, IstEmployment, True 

LoadDataToControls rstEmployment, cboRating, True » 
LoadDataToControls rstEmployment, cboAgree, True 
LoadDataToControls rstEmployment, cboFactors, True 
LoadDataToControls rstEmployment, cboFactorsl, True 

If I [FinishDate] = "12:00:00 PM" Then 

cmdSave. Enabled = True 
Else 

cmdSave . Enabled = False 
End If 
End With 

tabEmployment . Tab = 0 
txt Current Record. SetFocus 
End Sub . 

Private Sub cmdPreviouslciick ( ) 
If tabEmployment .Tab » 0 Then 

MsgBox "It is first page for Self Assessment already!", vblnf ormation + vbOKOnly, "Prevxou 
age" 
. Else 

tabEmployment . Tab = tabEmployment .Tab - 1 

frmEmployment. Caption = getTabCaption (tabEmployment .Tab) 
End If 
End Sub 



Private Sub cmdPreviousRecor<5L.Click( ) 
With rstEmployment 
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. MovePrevious 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord. Enabled = False 

crodNExt Record. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord. Enabled = True 

cmdNExtRecord. Enabled = True 
Elself .RecordCount = -AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNExtRecord. Enabled = False 
End If 

If ! [FinishDate] = "12:00:00 PM" Then 

cmdSave . Enabled = True 
Else 

cmdSave . Enabled = False 
End If 
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txtCurrentRecord = 
LoadDataToControls 
LoadDa t aToCont r ol s 
LoadDa taToCont rol s 
IioadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 
LoadDataToControls 



.AbsolutePosition 



r s t Emp 1 oymen t , 
rstEmployment , 
r s t Emp 1 oymen t , 
rs tEmployment , 
rs tEmployment , 
rstEmployment , 
r s t Empl oyment , 
rstEmployment , 
rstEmployment , 
rstEmployment , 
rstEmployment , 
rstEmployment , 



cboEmploymentStatus , True 
txtEmployment , True 
cboStaffs, False 
cboGenerallnfo, True 
chkGoals, True 
cboYesNo> True 
cboJobDi f f i cul ty , True 
IstEmployment, True 
cboRa t ing , True 
cboAgree , True 
cboFactors , True 
cboFactorsl, True 



End With 



tabEmployment .Tab = 0 
txtCurrentRecord . SetFocus 
End Sub 

Private Sub cmdPrint^Click ( ) ' 
Dim i As Integer 

If Printers . Count = 0. Then 

MsgBox "No printer found associating with this computer. Please add a printer to it and thi 
ou can print out the Service agreement ! " , _ 
vbjnformation vbOKOnly, ."Printer" 

Else. 

If rst -State = adStateOpen Then rst. Close 

rst.Open "Select * from employmentAgreement Where AssessmentSequence » " & rstEmployment ! (: 
rventionSequence] , cnn, adppenKeyset , adLockOptimistic 

If Not rst.BOF Then i if there an existing report, delete it then create a new report 

rst. Delete 
End If 
rst. Close 

If rst. State = adStateOpen Then rst. Close 

rst.Open "Select * . f rom employmentAgreement Where Assessment Sequence = " & rstEmployment ! [: 
.rventionSequence], cnn, adQpenKeyset, adLockOptimistic 
With rst 

If .BOF And -EOF Then 
;AddNew 

! [CaseNumber] » txtCaseNumber • . 

! [Episode] = txtEpisode 

1 [Assessment Sequence] = rstEmployment ! [In terventionSequence] 
I [ConsumerName] = txtConsumerName 
' ! [AssessmentDate] = txtEmployment (0)' 
I [Interviewer] « cboStaf f s .Text 
For i = 0 To 7 - 1 

If chkGoals (i) .Value « 0 Then 

.Fields (chkGoals (i) .Tag) = °" 
Else 

.Fields (chkGoals <i) .Tag) = "Yes" 
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End If 
Next 

For i a 11 To 17 

. Fields t cboYesNo ( i ) . Tag ) ■ cboYesNo ( i ) . Text 
Next 

For i = 20 To 25 

. Fields ( cboGenerallnf o ( i ) . Tag) = cboGenerallnf o ( i ) - Text 
Next 

.Update 
End If 
End With 

Set EmploymentAgreement .DataSource = rst 

EmploymentAgreement - PrintReport 
End If 
End Sub 

Private Sub cmdPrintFinal_Click ( ) 

Dim rsReport As 'New ADODB . Recordset 

Dim rsReport2 As New ADODB . Recordset 

Dim Filler As Integer * 

Dim Temp As Integer 

Dim Counselor As String , 

Dim CaseNo As String 

Dim Payer Sequence As Integer 

Dim PayerLocation As Integer 

Dim AuthID As String 

Dim Location As String 

Dim Achieved As String 

Dim NotAchieved As String 

Dim Staff As String 

Dim Visits As Integer 

Dim ServiceHrs As Single 

Dim ProgressSequence As Integer 

Dim Periodl As String 

Dim Period2 As String 

Dim GoalDesc As String 

Dim ObjDesc As String 

Dim G Achieve As String 

Dim OAchieve. As String 

Dim Ach As String • 

Dim Not Ach As String 

Dim GSeq As Integer 

Dim Summary As String * 65000 

Dim SumText As String 

Dim Begii As integer 

Dim BlankPosition As Integer 

Dim LeamingProcess As String 

Dim Techniques As String 

Dim Responsibility As String 

Dim Realistic As String 

Dim TempS tr As String 

Dim CodeValue As String 



Achieved = 0 X M 
NotAchieved » ° ° 

Set rsReport = New Recordset 
rsReport. CursorLocation = adUseCJLient 

• Retrieve CBVH counselor. Case No and PayerSeguence 

rsReport. Open "Select PayerContact , IDWithPayer. PayerSequence , PayerLocation From Payerlnfo 

• Where Consumerld = 0 & CustomerlD & ° And Agency = • " & AgencyCode & » ' " & _ 

And Episode = " & Episode & ° And CaseNumber « ' ■ & CaseNumber & ota & _ 
a And PayerlD = •150 ,B , cnn, adOpenForwardOnly, adLockOptimistic 

With rsReport 

If Not (.BOF Or . EOF) Then 
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.MoveFirst 

Counselor = I [PayerContact] 

CaseNo = ! [IDWithPayer] 

PayerSequence = ! [PayerSequence] 

Payerliocation = ! [PayerLocation] 
End If 
End With 
rsReport. Close 

1 Get the CBVH Location 

Set rsReport = New Recordset 

rsReport .Cur sorLocat ion « adUseClient 

rsReport . Open "Select Description From PayerLocation" & _ 

" Where PayerlD = , 150 ,tt & _ . jt 

- And Code ' n & PayerLocation & " ,D , cnn, adQpenForwardOnly, adLockOptimistn 

With rsReport 

If Not (.BOF Or .EOF) Then 
•MoveFirst 

Location = ! [Description] 
End If 
End With 
rsReport . Close 



• Get the Authorization Number for this Intervention 
Set rsReport = New Recordset 
rsReport . CursorLocation * adUseClient 

rSReport.Open "Select Authorizations From PayerAuth PA, Interventions I & _ 

» Where PA.Consumerld = " & Customer ID & ■ And PA. Agency = ,u & AgencyCode & 

**" o pa. Episode = ■ & Episode & ■ And PA . CaseNumber = ' ° & CaseNumber & • 1 ■ & _ 

■ And PA. PayerSequence = B £ PayerSequence fie _ 

" And PA. Consumer ID = I. Consumer ID And PA. Agency = I. Agency" & _ 

■ And PA. CaseNumber = i. CaseNumber And PA. Episode = I. Episode" & _ 
" And PA. InterventionSequence = I . InterventionSequence" & _ 

■ And I. interventions = -'050'" # cnn, adOpenForwardOnly, adLockOptxmxstxc 

With rsReport 

If Not (-BOF Or .EOF) Then 
.MoveFirst 

AuthID = ! [AuthorizationID] 
End If 

End With - 
rsReport . Close 

Set rsReport = Nothing 

• Total Service Hours 

Set rsReport = New Recordset 

rsReport .CursorLocation = adUseClient 

Visits =0 - ' 

ServiceHrs = 0 

rsReport. Open "Select Duration From Visits V" & _ 

■ Where ViCpnsumerld = " & CustomerlD & ■ And V. Agency = '» & AgencyCode & 

n And V. Episode * " & Episode & " And V. CaseNumber = & CaseNumber & ■ ' ■ & _ 

■ And V. InterventionSequence = » & rstEmpl oymenti [InterventionSequence] , . cnn, a 
nForwardOnly, adLockOptimistic 

With rsReport 

If Not (.BOF Or -EOF) Then 
.MoveFirst 
While .EOF = False 

Visits = Visits + ! [Duration] 
.MoveNext 
Wend 

End If . . 

End With 
rsReport. Close 
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ServiceHrs = 'Visits / 60 
Set rsReport « Nothing 



• Service Period ' 

Set rsReport = New Recordset 

rsReport.CursorLocation = adUseClient 

rsReport . Open "Select min (ServiceDate) as PI, max (ServiceDate) as P2 From Visits"* & _ 

* ■ Where* Consumer Id' = n & Customer ID & 0 And Agency - 1 ■ & AgencyCode & ■ * n & _ 
■ And Episode = ■ & Episode & 0 And CaseNumber = ' u & CaseNumber & ■ ' ° & _ 
11 And InterventionSequence = 0 & rstEmployment i [InterventionSequence] , cnn, adOp- 

orwardOnly, adXockpptimistic ^ 

With rsReport 

If Not ( .BOF Or .EOF) Then • 
. MoveFirst 

Periodl = ! [PI] 
Period2 = ! [P2] 
End If 
End With 
rsReport - Close 

Set rsReport = Nothing 



1 Get the Staff Assigned 
Set rsReport = New Recordset 
rsReport- Cur sorLocat ion = adUseClient 

rsReport . Open "Select StaffName From Staffs/ EmploymentAssessment E° & _ 

n Where E.Consumerld = " & Customer ID & " And E. Agency = ' " & AgencyCode & M,n & 
■ And E. Episode = ■ & Episode & " And E. CaseNumber = ■ 0 & CaseNumber & 0,0 & _ 
" And E. AssessmentSequence = " & rstEmployment ![ Asses smentSequence] & 
° And Staffs -Id = E. Interviewer" , cnn, adOpenForwardOnly, adLockOptimistic 

With rsReport 

If Not {.BOF Or . EOF) Then 
.MoveFirst 
1 Staff ■ J [StaffName] 
End If 
End With 
rsReport . Close 

Set rsReport = Nothing 



1 Retrieve Summary and Progress Sequence 
Set rsReport = New Recordset 
rsReport.CursorLocation = adUseGlient 

rsReport . Open "Select Summary, ProgressSeq From ProgressReport P n & _ 

" Where P.Consumerld « - & Customer ID & " And P. Agency - ,n & AgencyCode & S 
• And P. Episode = " & Episode & ■ And P. CaseNumber = '" & CaseNumber & " 1 " & _ 
. n -And P. Asses smentSequence = " & rstEmployment ! [Assessment Sequence] & _ 
0 And Interventions = '050' cnn, adOpenForwardOnly, adI#ockOptimistic 
i 

With rsReport 

If Not ( .BOF Or .EOF) Then 
.MoveFirst 

ProgressSequence = ! (ProgressSeq] 
Summary = ! [ Summary] 
End If 
End With 
rsReport .Close 



Set rsReport = Nothing 
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1 End of Service Provider Report 
Set rsReport = New Recordset 
rsReport.CursorLocation ~ adUseClient 

rsReport. Open "Select LearningProcess , Techniques, Responsibility, Realistic From Intervention 

' Extent E & T where I.Consumerld = ■ & Customer ID & " And I. Agency = 10 & AgencyCode & otn & 

■ And I. Episode = n & Episode & 0 And I.CaseNumber = ' n & CaseNumber & & - 

■ And I.InterventionSequence = " & rstEmployment ! ClnterventionSequence] & - 
" And interventionID = '050* ", cnn, adOpenForwardOnly, adLockOptimxstic 

With rsReport 

If Not .(.BOF Or .EOF) Then / 
.MoveFirst 

LearningProcess » i [LearningProcess ] 

Techniques = ! [Techniques] 

Responsibility = ! [Responsibility] 

Realistic = ! [Realistic] 
End If 
End With 
rsReport. Close 

Set rsReport = Nothing 

Temp = 1 * 

While Temp < 5 

If Temp = 1 Then CodeValue = LearningProcess 
If Temp = 2 . Then CodeValue = Techniques 
If Temp = 3 Then CodeValue = Responsibility 
If Temp = 4 Then CodeValue = Realistic 

Set rsReport » New Recordset 
rsReport.CursorLocation = adUseClient 

rsReport. Open "Select Description From Extent" & _ , nnHrn , 

» Where Code = • ° & CodeValue & " • " , cnn, adOpenForwardOnly, adLockOptimisti* 



With rsReport 

If Not (.BOF Or . EOF) Then 
.MoveFirst 

While .EOF = False 

TempStr = ! [Description] 
.MoveNext 
Wend 

End If 
End With 

If Temp ss l Then LearningProcess « TempStr 
If Temp = 2 Then Techniques = TempStr 
If Temp = 3 Then Responsibility = TempStr 
If Temp = 4 Then Realistic = TempStr 

rsReport : Close 
Temp = Temp + 1 
Wend 

Set rsReport = Nothing 



PrintBlankLines (4) 

Printer. FontSize = 12 

Printer. Font = "Arial" 

Printer. Print Spc<49); "Final Report" 

Printer . Font . Bold ■ True 

Printer. Print Spc(37); "Placement Services T Initial" 
PrintBlankLines (2) 
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Printer. Print Spc(89); "58- 

Printer. Print Spc(74); "Authorization No.: 

Printer. Font .Bold =? False 

Printer. Print Spc (82); AuthID 

PrintBlankLines (2) ^ 
Temp = Len ( txtConsumerName ) 

StntLTprint vMab & "Consumer Name: - & txtConsumerName ; Spc (Filler); -Case No: - & CaseNo 

Printer ".Print vbTab & "CBVH Counselor:"; Sped); Counselor. 
Printer. Print vbTab & "CBVH D.O.:"; Spc (6); Location 
PrintBlankLines (3) 

Sinteriprin^v^ ^Mab ft vbTab ft -Final Report Service Outcome" 
Printer. Font. Bold = False _ 

Printer . Print 
Printer. Print 

££"r:Pr£t B vb?ab ?vSwb ft vbTab ft "Total Hour Units Rendered: - ft vbTab; 
Printer. FontBold = False 
Printer. Print SeryiceHrs 
Printer. Print 

SS5:SSi B SS^ fvbTab ft vbTab ft "Total Service Period: - ft vbTab ft vbTab; 

Printer. Font. Bold = False 

Printer . Print Periodl & ■ to n . & Penod2 

PrintBlankLines (4) 

Snter:Pr?n? n ?bTab n 2 lighthouse" ft vbTab ft vbTab ft vbTab ft Staff ft vbTab ft vbTab ft Pate 
SnteriPrinf ^ft ^Agency Name" ft vbTab ft vbTab ft vbTab ft "Agency Signature" ft vbTab ft vbT. 
"Date" 

PrintBlankLines (3) trWPa . , ™wr a i>. - _" & vbTab 

Printer. Print vbTab & ■ Report Accepted" & vbTab & vbTab, _ - 

iri^iHSt" vbTab & *_ Not Accepted" & vbTab & vbTab & "CBVH Signature" * vbTab & vbTab & 



' Get the Goals from the IRA 
Printer .NewPage 

PrintBlankLines (5) , . 

Printer. Print Spc (68); "Achieved"; Spc (5) ; "Not Achieved 

Ach = " ° 
NotAch = " " 
LineCounter =0 

Set rsReport = New 'Recordset 
rsReport.CursorLocation = adUseClient 



rsReport.Open "Select GA. Goal ID, Achievement, Description, GoalSeq From GoalAchieye GA, Goals 
& - - Where GA. Consumer Id = " & CustomerlD & - And GA . Agency = ■■ & AgencyCode & ■"■ 

" And GA.Episode = - & Episode fc " And GA.CaseNumber^ ^^f^SlD" V & ' 
« And GA.ProgressSeq = 0 & Progress Sequence & tod ^' Goa "? ~ ^t^istic ~ 
• iid GA.IntlrventionlD = -050'", enn, adOpenForwardOnly , adLockOptunistic 

With rsReport 

If Not (.BOF Or .EOF) Then 
.MoveFirst 
While .EOF o False 

GoalDesc* = Mid (! [Description] , 1, 45) 
GAchieve = ! {Achievement] 

S* GAchieS^ 1 " Or GAchieve = "2" Or GAchieve = "3" Or GAchieve = "4" Or GAchieve 

" Then 

NotAch = "x" 



Printer. Print vbTab & "Goal: ■ & GoalDesc; Spc (Filler) ; vbTab & Ach & vbTab & vbTab 

otAch 

LineCounter = LineCounter + 1 
CheckLineCounter (LineCounter) 



* Get the objectives associated with this goal 
Set. rsReport2 » New Recordset 
rsReport 2 .Curs or Location = adUseClient 

rsReport2.Qpen "Select OA.GoallD, Achievement, Description From ObjectiveAchieve OA, 
ectives O" & _ 

Where OA . Consumer Id = ■ & CustomerlD & ■ And OA. Agency = ' • & AgencyCode & 0 1 ' 

■ And OA. Episode = ° & Episode & n And OA . CaseNumber = ' ■ & CaseNumber & 0,0 & _ 
" And OA.GoalSeq = ■ & GSeq & " And OA.GoallD = O.GoallD And OA.ObjectivelD = O. 
ectivelD" & _ ' 

° And OA. Achievement IS NOT NULL" , cnn, adOpenForwardOnly, adLockOptimistic 

With rsReport2 

If Not (.BOF Or .EOF) Then 
.MoveFirst 
- While .EOF = False 

ObjDesc = Mid( 1 [Description) , 1, 36) 
©Achieve = J [Achievement] 

If OAchieve = "1" Or OAchieve = "2" Or OAchieve = "3" Or OAchieve = "4" O: 

chieve = "5" Then 

NotAch = fl x" . 

Ach = ■ ° 
Else 

NotAch = "• ■ 

Ach = "X" 
End If 

Temp = Len (ObjDesc) 

Filler » 41 - Temp • , 

Printer. Print Spc(13); "Objective: " & ObjDesc; Spc (Filler); vbTab & Ach 
bTab Sc vbTab & NotAch 

LineCounter = LineCounter + 1 
CheckLineCounter (LineCounter) 
.MoveNext 

Wend 
End If 
End With 
rsReport2 .Close 

Set rsReport2 « Nothing 1 End of Objectives loop 

PrintBlankLines (1) 

LineCounter = LineCounter + 1 

CheckLineCounter (LineCounter) 

. MoveNext 

Wend 
End If 
End With 
rsReport . Close 

Set rsReport = Nothing ■ End of Goals Loop 

• Summary Narrative 
PrintBlankLines (1) . 
BegL =1 

Printer . Print vbTab & "Narrative:" 
LineCounter « LineCounter + 2 
CheckLineCounter (LineCounter) 
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Ach = 0 ■ 
Else 

NotAch = ■ ■ 

Ach = °X° 
End If 

Filler = 52 - Len (GoalDesc) 
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SumText = Mid (Summary, BegL, 90) 
BlankPosition = InStrRev( SumText, ° a ) 
SumText = Mid { SumText , 1* BlankPosition) 
Printer - Print vbTab & SumText 
BegL = BlankPosition + 1 
LineCounter = IiineCounter + 1 
CheckLineCounter (LineCounter) 

For Temp = 1 To 20 

SumText = Mid (Summary, BegL, 90) 

BlankPosition * InStrRev ( SumText , " a ) 

SumText = Mid (SumText, 1, BlankPosition) 

Printer. Print vbTab ft SumText 

BegL = BlankPosition + BegL * 

LineCounter = LineCounter + 1 

CheckLineCounter (LineCounter) 
Next 

PrintBlankLines (2) 
LineCounter = LineCounter +2 
CheckLineCounter (LineCounter) 

• End of Service Provider Report 

Printer. Print vbTab ft "Post -Service Provider Questionnaire 
Printer. Print 

LineCounter •= LineCounter + 2 



SSSr n S!^ consumer took part in learning process.- * vbTab ft vbTab ft L< 

Prin?er°Prlnt vbTab ft - 2) Extent consumer used techniques s/he learned." ft vbTab ft vbTab ft Te. 

Pr^ter.Print vbTab ft - 3) Extent consumer took responsibility for change." ft vbTab & vbTab ft : 

Ser'prSt vbTab ft - 4) Extent consumer was realistic about expectations." ft vbTab ft vbTab 
Realistic 

Printer . EndDoc 

\ 

End Sub 

Private Sub PrintBlankLines (num As Integer) 

Do While (num <> 0) 

Printer. Print . . 

num = num - 1 
Loop 

End Sub 

Private Sub CheckLineCounter (num As Integer) 

If num = 60 Then 

Printer . NewPage 

LineCounter =0 
End If 

End Sub 

2S2?.8f 22?2?5£2" is terminate assessment: or recommend external benefits,". 

OKOnly, "Question 5 instruction" • 
End Sub 

Private Sub cmdRecommendatioi\_Click( ) 
Dim tmpStr As String 
Dim i As Integer 



tmpStr = "Based on Consumer Self -Assessment .And Provider Ratings, 
If chkRecommendat ion. Count = 0 Then . „ 

tmpStr = tmpStr ft " no additional services are recommended. 
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<jpT£ chkRecomraendation. Count = 1 Then 
Ss^r = tnpStr & ■ the following additional service is recommended," 

ElS tnipStr = tmpstr & ■ the ' following additional services are recommended.' 
End If 

tmpStr = tmpStr & vbNewLine & vbTab 

FOr x E ch^ecommSda^nm^ue 0 ^ Then tmpStr - tmpStr * chfcHecommendation <i, -Tag * vbNewLin, 

& vbTab 
Next. 

MsgBox tmpStr, vbOKOnly, "Recommended Services" 
tabEmployment .Tab = 2 
tabEmployment .Tab » 3 
txtEmpioyment( 45) .SetFocus 

End Sub 

Private Sub cmdRecommendation_LostFocus ( ) 

" C ircSSoymStsJatus(0,. Il istIndex .= 2 Or cboEmploymentStatus (0, .Ustlndex = 3 Then 

IsShftTab = True 
tabEmployment .Tab = 8 
cboFactor s { 6 ) . SetFocus 
EXse 

IsSHftTab = True _ 

tabEmployment .Tab = 3 

cboFac torsi ( 4 ) . SetFocus 
End If 
End If 
End Sub 

Private Sub cmdRecommendationl_Click() 
Dim tmpStr As String 
Dim i As Integer 

tmpStr = "Based on Consumer Self -Assessment And Provider Ratings/ 
If chkRecommendat ion. Count = 0 Then 

tmpStr = tmpStr & " no additional services are recommended. 
Flseif chkRecommendat ion. Count = 1 Then 

SnpStr = Sstr &. » the following, additional service is. recommended. 

ElS tmpStr = tmpStr & " the following additional services are recommended. " 
End If 

tmpStr = tmpStr & vbNewIiine & vbTab 

F ° r xf ch^ecomSendaSm^ue 0 ^? Then tmpStr = tmpStr * ch*Recommendation<i> .Tag u vMMLJ 

& vbTab 
N6xt 

MsgBox tmpStr, vbOKOnly, "Recommended Services" 
tabEmployment . Tab = 7 
tabEmployment .Tab = 8 
txtEmployment ( 47 ) . Se tFocus 

End Sub 

Private Sub cmdSave_Click( ) 

Dim colEmploymeht As New Collection 

Dim i As integer 

On. Error GoTo err Save f 

colEmployment.Add cboEmploymentStatus 
colEmployment.Add txtEmployment 
colEmpioyment.Add cboStaffs 
colEmployment.Add cboGenerallnfo 
colEmployment.Add chkGoals 
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colEmployment .Add cboYesNo 
colEmployment. Add cboJobDif f iculty 
colEmployment .Add IstEmployment 
colEmployment -Add cboFactors 
colEmployment .Add cboFactorsl 
colEmployment . Add cboRating 
colEmployment .Add cboAgree 

If isDate(txtEmployment{50)) Then - If filing the assessment make sure the learning strategy 

■ and the factors are there 

If cboEmploymentStatus{0) .List Index = 2 Then • Job Placement 
If cboGeneralInfo(15) .Listlndex - -1 Then 
tabEmployment .Tab = 8 

cboGenerallnf o ( 15) .SetFocus x 
MsgBox -You have to select one item from the Learning Strategy!", vblnformation + vbOKOi 

y, "Strategy Learning" 
Exit Sub 
End If 

For i = 6 To cboFactors -Count - 1. 

If cboFactors (i) .Listlndex » -1 Then 
tabEmployment -Tab = 8 

cboFactors (i) . SetFocus . . _.„_ - 

MsgBox "You have to select one of the items from Factors!", vblnformation + vbOKOniy 

"Factors" 

Exit Sub 
End If 
Next 

Elself cboEmploymentStatus(O) .Listlndex = Q Or cboEmploymentStatus (0) -Listlndex = 1 Then ' Jo 
Retention 

If cboGeneralInfo(6) .Listlndex = -1 Then 
tabEmployment . Tab = 3 

cboGenerallnf o( 6) .SetFocus ' ^. . ^ , „ hnKf 

MsgBox "You have to select one item from the Learning Strategy!", vblnformation + vbOKC 

y, ■ Strategy Learning" 
Exit Sub 

End If ' 

For.i = O'To cboFactorsl .Count - 1 

If cboFactorsl (i) .Listlndex » -l.Then 
tabEmployment .Tab = 3 

' cboFactorsl (i) -SetFocus „v^vn«ii 

MsgBox "You have to select one of the items from Factors!", vblnformation + vbOKOni. 

"Factors" 

Exit Sub J 
End If 
Next 
End If 
End If 

If SaveDataToDB(frmEmploymerit, rstEmployment, colEmployment, "050", False) Then 'Call 
blic function to save data to DB 

MsgBox "Successfully saved the Assessment information!", vbOKOnly, Save 

If IsDate (txt Employment (50) ) Then 

cnn. Execute "Update Interventions Set PreConsumerScore = »■ & • txtConsumer Score & " ' , Pre 
VXderSC ° r txtProviderScore & " ; Where ConsumerlD = » & CustomerlD & - And Agency = ■ ■ & AgencyC 

And Episode = " & Episode & " And CaseNumber = '" & CaseNumber & t \ o 

■■ And Intervention^ = '050' And (EndDate = #12:00:00 PM# or EndDate IS NULL)" 

cnn. Execute "UPDATE EmploymentAssessment AS a INNER JOIN Interventions AS b ON (a.CaseNun 
= b.CaseNu^rr ^ Igode = b.Episode) AND (a. Consumer ID = b.ConsumerlD) SET a . InterventionSec 

ce = b.InterventionSeguence" & _ „ , . r ol ATan fH En dD£ 

".WHERE b. InterventionID = '050' and b. CaseNumber - & CaseNumber & ° AND (b.EndDc 



1 
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a #12:00:OOPM# OR b.EndDate IS NULL) 0 & _ 
■ AND a.InterventionSe<juence =0" 

End If 

If IsNewRecord Then 

rstEmployment . Re query 

txtSequencyNo = rs t Employment ! [AssessmentSeguence] 
End If 

IsNewRecord =» False 
Set colBnployment = Nothing 
•End If 
Exit Sub 

err Save : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 
End Sub 

Private Sub Formic tivate ( ) 

* 

On Error GoTo Err handler 

If IsVisuallnfoClicked Then Exit Sub 
txtConsumerName = FirstName fie n & LastName 
txt Phone = PhoneNo 
txtAddress = Address 
txtCaseNumber = CaseNumber 
txtEpisode = Episode 

IsArrowKey = 20 'Avoid Combo click event 

LoadControlsItems cboStaffs, False 'Add every description from database to combobox oi 

tbox 

Set rst = New ADODB . Recordset 'create recordset object 

rst .CursorLocation = adUseClient 

rst. Open "Select AgeAtOnset. SelfVisualAny, Employed, JobJeopardy From Triage Where Consumer 
" & - 

Customer ID, cnn, adOpenForwardOnly, adLockReadOnly 

With rst 

If Not (.BOF Or .EOF) Then 
.MoveFirst 

hasVision = i {Self Visual Any] 

If ! [employed] - 1 Then 

If ! [jobjeopardy] = 1 Then 

cboEmploymentStatus(O) .Listlndex = 0 
Else 

cboEmploymentStatus(O) .Iiistlndex = 1 
End If 

Elself ! [employed] = 2 Then 

cboEmploymentStatus(O) .Listlndex = 2 
End If 
End If 
End With 

txt Intervention = "Employment 0 
rst. Close 

Set rstEmployment « New ADODB . Recordset 
rstEmployment .CursorLocation = adUseClient 

rstEmployment. Open "Select * From Employmentassessment Where ConsumerlD = ° & CustomerlD & _ 
■ And Agency = 1 n & AgencyCode & n 1 And Episode = ° & Episode & * And CaseNumber = ■ ° * 
CaseNumber & * * And Int erven tionID = '050' Order By Assessment Sequence DESC , cnn, „ 
adOpenKey s e t , adLockOpt imi s t ic 
With rstEmployment 

txtRecordNo « .RecordCount 
. If Not (.EOF And -BOF) Then 'Have record for this client and load it t< 

m . 

txtCurrentRecord = .AbsolutePosition 

LoadDataToControls rstEmployment, cboEmploymentStatus, True 
LoadDataToControls rstEmployment, txtEmployment , True 
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LoadDataToControls rstEmployment. cboStaffs, False 
LoadDataToControls rstEmployment, cboGenerallnfo, True 
LoadDataToControls rstEmployment,. chkGoals, True 
LoadDataToControls rstEmployment. cboYesNo, True 
LoadDataToControls rstEmployment, cboJobDxf ficulty. True 
LoadDataToControls rstEmployment. IstEmployment, True 

LoadDataToControls rstEmployment, cboRating, True . . 

LoadDataToControls rstEmployment, cboAgree, True 
LoadDataToControls rstEmployment, cboFactors, True 
LoadDataToControls rstEmployment, cboFactorsl, True 

' ' if .RecordCount > .AbsolutePosition Then cmdNExtRecord . Enabled = True 

If . [FinishDate) <> "12:00:00 PM« And IsDate ( ! [FinishDate] ) Then 
cmdSave. Enabled = False 
cmdPrint. Enabled = True 
cmdClear. Enabled = True 

Else 

cmdSave. Enabled =* True 
cmdPrint . Enabled = False 
cmdClear. Enabled = False 
End If 

Else 

cmdNExtRecord. Enabled = False - 
cmdPreviousRecord. Enabled = False 
txtCurrentRecord = 0 

End If 
End With 

tabEmployment -Tab =0 
txtConsumerName . SetFocus 
IsArrowKey = 0 
Exit Sub 

MsgBoll^lDescription, vbCritical + vbOKOnly, "Form Load* 
End Sub 

Private Sub Form_Unldad (Cancel As Integer) 
Dim response As Integer 
Dim i As Integer 

If isFileDateChecked Then 

If rst. State = adStateOpen Then rst. Close 

Set rst = Nothing 

rstEmployment .Close 

Set rstEmployment = Nothing 

Set f rmEmployment = Nothing 

ElS If Trim(txtEmployment(40)) = - And ^-^^enf Assessment ?», vbQuestion + vbYesNo, 
response = MsgBox(°Have you finished the Employment Assessmen 

ile Date 0 ) ' 

" fS^^SSZST^ File Date ,-. vblnformation + vbOKOnly. -File Date' 

txtEmployment ( 40 ) . SetFocus 

Cancel = True 

E1S If rst. State = adStateOpen Then rst. Close 
Set rst = Nothing 
rstEmployment .Close 
Set rstEmployment = Nothing 
Set f rmEmployment = Nothing 

vbYesNo, "File Date") 

" response = MsXoxT'^ease use Save button to save the assessment information-. vbQue 
' n + vbOKOnly, "File Date") 
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If response « vbYes Then 

cmdSave . SetFocus 

Cancel = True 
End Xf 

Elself cmdSave. Enabled = True Then 

txtBmployment{40) = 00 
End If 

Elself IsDate (Trim(txt Employment < 40) ) ) And Not cmdSave . Enabled Then 
If rst. State = adStateOpen Then rst. Close 
Set rst = Nothing 
rstEmployment .Close 
Set rstEmployment « Nothing 
Set f nnEmployment ■ Nothing • 
End If 
End If 
End Sub 

private Function getTabCaption( tablndex As Integer) As String 

Select Case tablndex 
Case 0 

getTabCaption = "A. General Information" 
Case 1 

getTabCaption « "B, Job Retention - Employment" 
Case 2 

getTabCaption = °C. Job Retention - Self Assessment" 

° aS getTabCaption = "D. Job Retention - Service Provider Rating, Factors And Learning Stratec 
Case 4 

getTabCaption = "E. Counselling, Placement && Supported - Vocational" 
Case 5 

getTabCaption = "F. Counselling, Placement && Supported - Job History" 

° aS getTabCaption = "G. Counselling, Placement && Supported - Consumer Self -Assessment" 

° aS getTabCaption = "H. Counselling, Placement && Supported - Consumer Self-Assessment And Si 
ice Provider Rating" 

getTabCaption = -I. Counselling. Placement && Supported - Service Provider Rating. Learn: 
Strategy And Factors' 

Case 9 * 

getTabCaption = "J. Goals" 
Case 10 

getTabCaption = "K. Employment Services Agreement - Service Agreement" 
End Select 

End Function . 

Private Sub CountScoreO 
Dim i As Integer 
Dim tmpValue As Integer 
Dim taskA As -Long- 
Dim taskB As Long 
Dim taskD As Long 
Dim taskE As Long 
Dim avgScor.e As Single 

If cboGeneralInfo(15) .Listlndex = -1 Then 
tabEmployment .Tab = 8 

cboGenerallnfo ( 15 )♦ SetFocus § _^ _ . . ^ . „u n vnniv 

MsgBox "You had to select one of items from Strategy Learning! 0 , vblnf ormatxon + vbOKOnly, 

rategy Learning" 

Exit Sub 
End If 

For i =5 0 To cboFactors. Count - 1 

If cboFactors (i) .Listlndex = -1 Then 
tabEmployment.Tab =8 

X tSEF%££\£ toleLct one of items from Factors!-, vblnf ormation ♦ vbOKOnly. "Facto. 



For i •= 9 To choJobDiff iculty. Count - 1 'count the score for task A 

If cboJobDif f iculty (i) .Listlndex = -1 Then 
taskA. = taskA + 4 

tmpValue = cboJobDif f iculty (i) .ItemData (cboJobDif f iculty (i) .Listlndex) 
If tmpValue = 5 Then 'User select "Refused", count 1 for this item 

taskA = taskA + 1 

Else . 

taskA = taskA + tmpValue 
End If . 
End If 
Next 

If cboGenerallnfo (14) .Listlndex = -1 Then 

taskA = taskA +4 
Else 

tmpValue = cboGenerallnfo ( 14 ). ItemData (cboGenerallnfo (14) .Listlndex) 

If tmpValue = 5 Then 'User select ° Refused" , count 1 for this item 

taskA = taskA + 1 
Else 

taskA = taskA + tmpValue 
End If 
End If 



tmpValue" = 0 

For i = 6 To cboRating. Count - 1 

If cboRating (i) .Listlndex = -1 Then 'user does'nt select one, count 10 for this item 

taskB = taskB +10 
Else 

tmpValue = cboRating (i) .ItemData (cboRating (i) .Listlndex) 

If tmpValue = 11 Then 'User select "Refused", count 1 for this item 

taskB = taskB + 10 

Else i 1 

taskB = taskB + tmpValue 
End If 
End If 
Next 

taskD = cboGenerallnfo (15) .ItemData (cboGenerallnfo (15) .Listlndex) 
tmpValue = 0 

For i = 0 To cboFactors . Count - 1 

Select Case cboFactors (i) . ItemData (cboFactors (i) .Listlndex) 

Case -3: tmpValue = 120 

Case -2 : tmpValue = 110 

Case -1: tmpValue = 105 

Case 0: tmpValue - 91 

Case 1: tmpValue =80 

Case 2 : tmpValue =60 

Case 3 : tmpValue =25 
End Select 

taskE = taskE + tmpValue 
Next 

txtConsumerScore = taskB * 1.9 
txt Provider Score = taskA * 1# 

avgScore = ((taskA * 1.9) + (taskB * 1#) + taskD + (taskE / 7))*/ 4 
txtEmployment (47) = CLng (avgScpre) 
txtEmployment(51) = Format (taskA * 1.9, »##")* 
txtEmployment (52) = Format(taskB * 1#, °##°). 
txtEmployment (53) = taskD 

txtEmployment (54) ' = Format (taskE / 7, °##") 
txtEmployment (55) = Format ( avgScore , u ##°) 
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Exit Sub 
End If 
Next 



Select Case CLng (avgScore) 
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rase 0 To 40: txtEntployment (48) = "Level 4 

Casl 41 To 60: - txtEmployment (48) = "Level 3" 
Case 11 txtEmployment<48) - "Level 2" 

txtErrtployment(48) = "Level 1" 
txtEmployment(48) = "No Service Needed 



Case 61 To 80 
Case 81 To 90 
Case 91 To 100: 
End Select 
End Sub 

Private Sub Count Scorel ( ) 

Dim i As Integer 

Dim tmpValue As Integer 

Dim taskA As Long 

Dim taskB As Long 

Dim taskD As Long N 

Dim taskE As Long 

Dim avgScore As Single 

If c boGeneralInfo( 6) .List Index = -1 Then 

tabEmployment . Tab = 3 _ 
SSS^S^l^S^cam of items from Strategy Learning.-, vblnformation + vbOKOnly. . 

rategy Learning". 

Exit Sub 
End If 

For i = 0 To 4 • 
If cboFactorsl(i) .Listlndex = -1 Then 
tabEmployment. Tab = 3 

2£? °you ( hia S to F select one of items from Factors,", vblnformation + vbOKOnly, 'Factors 

Exit Sub 
End If 
Next 

Q To g ' 'count the score for task A 

F ° r if cboJobDifficulty(i) , Listlndex = -1 Then 
taskA = taskA + 4 

El lrSvalue C ^5°Tnen fiCUlty(i) '"^sif 222? "SSS? for- tbis item 
taskA = taskA + 1 
Else , 
tas kA = taskA + tmpValue 

End If 
End If 
Next 

tmpValue =0 

F ° r xf ii2iu> = *- '«« does ' nt sel6Ct ° ne ' COUnt 10 

taskB = taskB +10 

ElS tmpValue = cboRatingU) ^^^^^ 1 ^^SSSLa' . count 1 for tbis item . 
If tmpValue = 11 Tnen u =»^ 
taskB = taskB +10 

Else . , • 

taskB = taskB + tmpValue 

End If 
End If 
Next 



taskD = cboGeneralInfo(6).ItemData(cboGeneralInfo(6). Listlndex) 
tmpValue =0 

F ° r Selec°t SLfSSSS^I^t.(<^t»«l(i) .Listlnde*, 
Case -3: tmpValue = 120 
Case -2: tmpValue = 110 
Case -1: tmpValue - 105 
Case 0: tmpValue * 91 
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Case 1: tmpValue = 80 
Case 2:. tmpValue - 60 
Case 3: tmpValue = 25 
End Select 

taskE = taskE + tmpValue 
Next 

txtConsumerScore = taskB * 1-7 
txtProviderScore = taskA * 2.8 
avgScore = ((taskA * 2.8) + (taskB * 1.7) 
txtEmployment (45) = CLng (avgScore) 

txtEmployment (56) = Format (taskA * 2.8, 

txtEmployment (57) = Format ( taskB * 1.7, 

txtEmployment(58) = taskD 

txtEmployment(59) = Format (taskE / 5, "## ) 

txtEmployment(60) = Format (avgScore, 

Select Case Cling (avgScore) 
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+ taskD + (taskE / 5) ) / 5 



##") 
##») 



txtEmployment (46) 
txtEmployment ( 46 ) 
txtEmployment ( 46 ) 
txtEmployment (46) 
txtEmployment ( 46 ) 



"Level 4° 
"Level 3° 
"Level 2° 
"Level 1" 

"No Service Needed" 



1 
1 
1 
1 

1 
1 



SSI 
SSDI 
AFDC 
TANF 

Food Stamps 
Section 8 

• Discontinue use 



Case 0 To 40: 
Case 41 To 60: 
Case 61 To 80: 
Case 81 To 90: 
Case 91 To 100: 
End Select 
End Sub 

Private Sub Is tEmplo$rment,JjOStFocus (index As Integer) 

If Index = 1 Then 

If CheckForTab Then - 
If IstEmployment(l) .Listlndex <> 2 Then tabEmployment . Tab = 5 

End If 
El self Index = 2 Then 

If IstEmployment (Index) .SelCount > 0 Then _ 

If lstEmployment(Index).Selected(0) Then chkGoals 22 -Value - 

If IstEmployment (Index) .SelectedU) Then chkGoals (23 .Value = 

If IstEmployment (index) .Selected(2) Then chkGoals 24 .Value = 

If IstEmployment (Index) .Selected (3) Then chkGoals 25 .Value - 

If IstEmployment (Index). Selected^) Then chkGoals 26 -Value = 

If IstEmployment (Index). Selected(5) Then chkGoals (27) Value - 

If Not IstEmployment (index) .Selected(6) Then chkGoals (6) .Value 
entitlements - goal 
End If 

If CheckForTab Then 

If cboEmploymentStatus(O) .Listlndex <> -1 Then 
If cboEmploymentStatus(O) .Listlndex <> 2 Then 

tabEmployment. Tab =1 
Else 

tabEmployment .Tab =4 

End If „ _ 

Elself cboEmploymentStatus(l) .Listlndex <> -1 Then 

tabEmployment .Tab = 4 

ElS MsgBox "Please select dne'of the Employment statuses!", vblnf ormation + vbOKOnly, 
yment Status" 
End If 
End If 

End If 
End Sub 

Private Sub tabEmployment_Click(PreviousTab As Integer) 
Dim i As Integer 

If -IsArrowKey > 0 Then Exit Sub 
Tab" t 
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Exit Sub 

Elself cboEmploymentStatus(O) .Listlndex <> -1 Then 
If cboEmpl6ymentStatus(0) .Listlndex <> 2 Then 

•If . tabEmployment. Tab > 3 And tabEmployment .Tab < 7 Then 
tabEmployment .Tab = 1 

If Not isShftTab Then txtEiroployment ( 9 ). SetFocus 
IsShftTab = False 

frmEmployment. Caption = "B. Job Retention - ESnployment* 
•Else 

• 'End If 

Else ^ . 

•If tabEmployment. Tab = 1 Or tabEmployment .Tab = 2 Or tabEmployment . Tab =» 3. Then 
tabEmployment .Tab = 4 

If Not IsShftTab Then cboGenerallnf o (9) .SetFocus 

IsShftTab ?= False ; 
frmEmployment. Caption » "E. Counselling, Placement && Supported - Vocational 
•End If 
End If 
Exit Sub 
Else 

•If tabEmployment. Tab =1 Or tabEmployment . Tab = 2 Or tabEmployment . Tab = 3 Then 
tabEmployment .Tab = 4 

If Not IsShftTab Then cboGenerallnf o (9) . SetFocus 

IsShftTab = False . 
frmEmployment. Caption - "E. Counselling, Placement && Supported - Vocational 
•End If 
End If . 
Elself PreviousTab = 3 Then 

If cboGeneralInfo< 6) .Listlndex = -1 Then 
tabEmployment . Tab = 3 

cboGenerallnf o ( 6 ) . SetFocus w>™ 
MsgBox -You had to select one of items from Strategy Learning! 0 , vblnformation + voOKO 
"Strategy Learning" 
Exit Sub 
End If 

For i = 0 To 4 

If cboFac torsi (i) .Listlndex = -1 Then 
tabEmployment .Tab = 3 

cboFactorsl(i) .SetFocus ^«„w, 
MsgBox "You had to select one of items from Factors! 0 , vblnformation + vbOKOnly, I 

rs" 

Exit Sub 
End It 
Next 

Elself PreviousTab = 8 Then 

If cboGenerallnf o ( 15) .Listlndex = -l.Then 
tabEmployment .Tab = 8 / 

cboGenerallnf o< 15) .SetFocus . 
MsgBox M You had to select one of items from Strategy Learning!", vblnformation + vdok< 
"Strategy Learning" 
Exit Sub 
End If 

For i = .0 To cboFactors . Count - 1 

If cboFactors (i) .Listlndex = -1 Then 
tabEmployment. Tab - 8 

cboFactors ( i ) . SetFocus wv*w_i « ■ 

MsgBox "You had to select one of items from Factors!", vblnformation + vbOKOnly, 
rs" 

Exit Sub 
End If 
Next 
End If 



If tabEmployment*. Tab = 0 Then 
cboStaf f s . SetFocus 

frmEmployment .Caption = "A. General Information" 
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Elself tabEmployment . Tab = 1 Then 

If Not IsShftTab Then txtEmployment (9) .SetFocus 
IsShftTab = False 

f rmEmployment .Caption = °B. Job Retention - Employment" 
Elself tabEmployment .Tab = 2 Then ' 

If Not IsShftTab Then cmdlns t rue t .SetFocus 
IsShftTab = False * 

f rmEmployment .Caption = "C. Job Retention - Self Assessment 0 
Elself tabEmployment . Tab = 3 Then 

If Not IsShftTab Then cboRating(O) .SetFocus 
IsShftTab = False 

f rmEmployment . Caption = "D. Job Retention - Service Provider Rating, Factors And Learning 
tegy 0 

Elself tabEmployment . Tab = 4 Then 

If Not IsShftTab Then cboGenerallnf o (9) .SetFocus 
IsShftTab = False ' 

f rmEmployment .Caption = "E. Counseling, Placement && Supported - Vocational 11 
Elself tabEmployment .Tab = 5 Then 

If cboEmployment Status (1) .List Index = 3 Then • If status is "not previous employed", 
tabEmployment .Tab - 6 1 skip to Consumer Self -Assessment 

f rmEmployment .Caption = n G. Counseling, Placement && Supported - Consumer Self -Asses smen 
cboGeneralInfo(25) .SetFocus 

End If 

If Not IsShftTab Then txtEmployment (25) .SetFocus 
IsShftTab = False 

f rmEmployment .Caption = *F. Counseling, . Placement && Supported - Job History" 
Elself tabEmployment . Tab = 6 Then 1 
If Not IsShftTab Then cboGenerallnf o{ 12) .SetFocus 
IsShftTab = False 

f rmEmployment .Caption = "G. Counseling, Placement && Supported - Consumer Self -Assessment" 
Elself tabEmployment . Tab = 7 Then 

If Not IsShftTab Then cboScaleRating (9) .SetFocus 
IsShftTab = False 

f rmEmployment -Caption = n H. Counseling, Placement && Supported - Consumer Self -Assessment 
Service Provider Rating" 
Elself tabEmployment .Tab = 8 Then 

If Not IsShftTab Then cboGenerallnf o (15) .SetFocus 

IsShftTab = False . 

f rmEmployment. Caption = °I. Counseling, Placement && Supported - Service Provider Rating, 
ning Strategy And Factors" 
Elself tabEmployment. Tab = 9 Then 
If Not IsGoalsClicked Then 

If Not IsShftTab Then cmdGoals. SetFocus 
IsShftTab = False 

f rmEmployment .Caption = "J. Employment Services Agreement" 
End If 
End If 
End Sub 

Private Sub txtCurrentRecord^Los t Focus ( ) 

If CheckForTab Then 
cboStaf f s . SetFocus 

f rmEmployment .Caption = "General Information ". 
End If • 
End Sub 

Private Sub txtEmployment_Change( Index As Integer) 

If Index = 15 Or Index = 41 Or Index = 43 Then 
If Len (txt Employment (Index) ) = 4 Then 

If Not IsNumeric(Mid(txtEmployment (Index) , 2, 3)) Then 

MsgBox "Please enter numberic number for phone number! 0 , vblnf ormation + vbokonly, " 
ne Number" 

txtEmployment (Index) =? Mid (txtEmployment (Index) , X, 2) 
txtEroployment (Index) .SelStart = 2 
Else • 

txtEmployment (Index) = txtEmployment (Index) & ")- D 
txtEmployment (Index) .SelStar;t = 7 
End If 
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Elself Len (txtEmployment (Index) ) = 9 Then 

If Not IsNumeric (Mid(txtEnqployment (Index) , 7, 3)) Then . ^ at .. . . vhOKOnlv a p 

MsgBox "Please enter numberic number for phone number! n , vblnformatxon + vbOKOniy, p 

ne Number" 

txtEmployment (Index) = Mid (txtEmployment ( Index ) , 1, 6) 
txt Employment (Index) .SelStart = 7 

txtEmployment (Index) = txtEmployment (index) & °- a 
txtEmployment (Index) .SelStart =11 , 
End If 

Elself Len ( txtEmployment ( Index) ) = 14 Then 

If Not IsNumeric (Mid ( txtEmployment ( Index) , 11, 3)) Then ', WA . lv „ r 

MsgBox. "Please enter numberic number for phone number!", vblnformation + vbOKOniy, I 

ne Number 0 „ ^ _ _ . „. 

txtEmployment (Index) = Mid (txtEmployment (Index) , 1, 10) 

txtEmployment ( Index) . SetFocus 

End If 

End If 

End If 

End Sub 

Private Sub txtEmployment_GotFocus (Index As Integer) 

" ^o^ Then ■ "Not previously employed 0 for employment si 

US * cboGeneralInfo<12>. SetFocus ' Skip to Cc»«~^«-^B««t Questions 

chkGoals(3).Value = 1 ' complete an internship checkbox 

End If 
. End If 

If Index = 15 Or Index = 41 Or Index = 43 Then 
txtEmployment (Index) = "(" 

txtEmployment (Index) .SelStart = 2 : 
End If 
End Sub 

Private Sub txtEmployment_LostFocus (Index As Integer) 
Dim tmpStr As String 
Dim tmpMonth As Long 
Dim tmpYear As Long 

If Index = 10 Then 

If CheckForShf tTab, Then 
IsShf tTab = True 
tabEmployment. Tab = 0 
End If . ^ ^ 

Elself Index * 15 Or Index = 41 Or Index = 43 Then 

If txtEmployment (Index) = " (° Then txtEmployment ( Index) =. 
Elself Index = 16 Then 
If CheckForTab Then 

tabanployment.Tab = 2 
End If 
Elself Index = 24 Then 
If CheckForTab Then 

tabEmployment .Tab = 5 
End If 
Elself Index =26 Then 

If CheckForShf tTab Then 
IsShftTab = True 
tabEmployment .Tab = 4 • 

If lstEmployment(l) *ListIndex = 2 Then 

IstEmployment (1) .SetFpcus 
Else 

txtEmployment (25) .SetFocus 
End If 
End If 
Elself Index = 29 Then 

If Trim( txtEmployment ( Index) ) <> Then 

tmpMonth = DateDiff (V, Trim (txtEmployment (Index) ) , Now) 
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tmpYear = tmpMonth / 12 
tmpMonth = tmpMonth Mod 12 
If tmpYear > 1 Then 

tmpStr = tmpYear & ° years" 

chkGoals{3) .Value = 1 
El self tmpYear » 1 Then 

tmpStr = tmpYear & 0 year" 
End If 

If tmpYear >• 0 Then 

If tmpMonth > 1 Then 

tmpStr = tmpStr & ■ and n & tmpMonth & ° monthes" 
El self tmpMonth = 1 Then 

tmpStr = tmpStr & " and ° & tmpMonth & ° month 0 
End If 
Else 

If tmpMonth > 1 Then 

tmpStr .= tmpMonth & n monthes" 
. Elself tmpMonth = 1 Then 

tmpStr = tmpMonth & " month 0 * 
End If 
End If 

txtEmployment (30) = tmpStr 
End If 
Elself Index =38 Then 
If CheckForTab Then 

tabEmployment .Tab = 6 . 
End If 
End If 
End Sub 

Private Sub txtEmployment_Validate ( Index *s Integer, Cancel As Boolean) 

If Index = 1 Or Index = 7 Or Index = 8 Or Index = 10 Or Index = 21 Or Index = 22 Or _ 
Index = 27 Or Index =33 Or Index =37 Then 
If Trim < txtEraployment (Index) ) <> "" Then 

If Not isNumeric (txtEmployment (Index) ) Then , ^ T ,^_ , 

MsgBox "Please enter numeric number in this fields", vblnformatxon + vbOKOnly, "Nume 

Number" 

txtEmployment ( Index) = "" 
Cancel = True 
End If 

End If . 
Elself Index = 0 Or Index = 2 Or Index = 29 Or Index = 50 Then 
If txtEmployment (Index) <> oa Then 

If Not lsDate(Trim(txtEmployment(Index))) Then , 

MsgBox "Please enter the date into this field!-, vblnf ormatxon + vbOKOnly, -"Date 
txtEmployment (Index) = "" 

Cancel = True _ 
Elself DateValue(Trim(txtEmployment (Index))) - DateValue (Date) > 0 Then rt 
MsgBox -Please enter the date into this field not later than. Today !" , vblnf ormatxon 

OKOnly, "Date" 

txtEmployment (Index) = " n 
Cancel = True 
End If ' 
End If 
End If 
End Sub 

Private Sub CountGoalsO / 
Dim i As Integer 

For i = 0 To cboAgree. Count - 1 
Select Case i 

Case 0 To 1 % 

If cboAgree (i) .Text = "Yes" Then chkGoals(O) = 1 

Case 1 To 4 ...... 

If cboAgree (i) .Text = "Yes" Then chkGoals(l) * 1 

Case 5 To 7 
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If cboAgree(i) .Text = "Yes" Then chkGoals(2) 
Case 8 ^ 

If cboAgree(i) .Text = "Yes" Then chkGoals(3> 
Case 9 To 11 

If cboAgree(i) .Text = °Yes B Then chkGoals(4) 
Case 12 To 13 

If cboAgree(i) -Text = n Yes 9 Then chkGoals(5) 
Case 14 To 19 

If cboAgree(i) .Text = "Yes 0 Then chkGoals(6) 
End Select - 
Next 
End Sub 



1 
1 
1 
1 
1 
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Option Explicit 
Public IsNewRecord As Boolean 
Private AgencyName As String • 
Private rstQA As ADODB. Recordset 
Private rsAgency As ADODB. Recordset 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdOverallScore_Click( ) 
frmOverallScore.Show vbModal 
End Sub 

Private Sub cmdSave_Click( ) 
SaveRecords 




End Sub 



Private Sub SaveRecords < ) 

Dim tmpParticipantNumber As String 

Dim tmpInterviewDate As Date * 

Dim tmpStaff As String 

Dim tmpFrequencyl As String 

Dim tmpFrequency2 As String 

Dim tmpPrequency3 As String 

Dim tmpFrequency4 As String 

Dim tmpFrequency5 As String . 

Dim tmpSatisfaction As String 

Dim tmpActivity As String 

Dim tmpFrequencyTwo As. String 

Dim tmpEf feet As String 

Dim EndDatel As Date 

Dim tmpStr As String 

1 Mandatory fields 

If Trim(txtParticipantNumber) = "" Then 

MsgBox "You must enter a Participant Number!", vbOKOnly, "Save 0 

txtParticipantNumber. SetFocus 

Exit Sub 
End If. 

If Trim(txtlnterviewDate) = "" Then 

MsgBox "You must enter an Interview Date!", vbOKOnly, "Save" 

txtlnterviewDate . SetFocus 

Exit Sub , 
End If 

If cboStaf fs.Iiistlndex « -1 Then 

MsgBox ."You must enter a Staff .Name! ■ , vbOKOnly, "Save" 

cboStaf f s . SetFocus 

Exit Sub 
Else 

tmpStaff = cboStaf fs.ltemData (cboStaf fs.Listlndex) 
End If 

If cboActivity.Listlndex = -1 Then 

MsgBox "You must answer the activity level question!", vbOKOnly, "Save 

cboActivity. SetFocus 

Exit Sub 
Else 

tmpActivity « cboActivity . I temDat a (cboActivity .List Index) 
End If 

If cboFrequency2.ListIndex = -1 Then ( 
MsgBox "You must answer the social integration question!", vbOKOnly, save 
cboFrequehcy2 . SetFocus 
Exit Sub 
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Else 

tmpFrequencyTwo = cboFrequency2 . ItemData(cboFrequency2 .Listlndex) 
End If 

If M sgBox f -Su L iu^ n answer"^ lection independently question-. vbOKOnly. "Save- 

cboEf f ec t . Se tFocus 

Exit Sub 
Else 

tmpEffect « cboEffect.ItemData(cboEffect. Listlndex) 
End If 

If cboFrequencyl(O) .Listlndex = -1 Then 
tmpFrequencyl = on 

Bl t^)Freauencyl = cboFrequencyl (0) . ItemData (cboFrequencyl (0) .Listlndex) 

End If - 

If cboFrequencyl (1) .Listlndex = -1 Then 
tmpFrequency2 = 00 

El tJpFrequency2 » cboFrequencyl ( 1 ) - ItemData ( cboFrequencyl ( 1 ) . Listlndex) 
End If • j 

If cboFrequencyl <2) .Listlndex « -1 Then 
tmpFrequency3 = 

El tmpFrequency3 « cboFrequencyl (2) .ItemData ( cboFrequencyl (2) .Listlndex) 
End If 

If cboFrequencyl (3) .Listlndex o -1 Then 
tmpFrequency4 = " 0 

E1 t^pFrequency4 = cboFrequencyl < 3 ) . ItemData (cboFrequencyl ( 3 ) . Listlndex) 
End If 

If cboFrequencyl < 4) .Listlndex * -1 Then 
tropFrequencyS = aa 

El t^pFrequency5 = cboFre<iuencyl (4) .ItemData (cboFrequencyl (4) .Listlndex) 
End If 

If cboSatisf action. Listlndex = -1. Then 
tmpSatisf action = DO 

El tJpSatisf action = cboSatisf action. ItemData (cboSatisf action. Listlndex) 

End If 

If Trim(txtEndDatel) = " 0 Then 

EndDatel = "12:00:00 PM" 
Else 

EndDatel = txtEndDatel 
End If . 

If execute c5LL3£ Sency, Episode. CaseNunfcer ^ipan^er - 

' -mterviewDate, Interviewer. Appointments, Needs. Helpful, Respect, Decisions, 

■Satisfaction. Activity, Social. Functioning. " ft _ Wssode ft M . 

-EndDatel) VALUES .( " & CustomerlD & • , " ft AgencyCode & . & Episode & . 

CaseNurnber ft - & . ... .. & txtI nterviewDate ft - » Wstaff ft " ' . - 

Frequencyl ft" ° ^^S^^ & .. § „ „ tmpFre<3Uency3 ft ... -ft t,npFre«uency 4 ft.-. - * 

• enCy5 * "tmpSatisf action & ••. fc tmpActivity ft "ft tmpFrequencyTwo ft " & - 

tmpEffect ft "•, ' " & EndDatel ft «•)" 

Else 
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cnn. Execute "UPDATE QA Set ParticipantNumber = 1 ° & txt ParticipantNumber & " ' , InterviewDate = 
& txtlnterviewDate & 

•'■ , Interviewer = • ■ & tmpStaf f & " * , Appointments « 1 " & tmpFreguencyl & " 1 , N€ 
= * 0 & tropFrequency2 & _ 

" ' , Helpful * * " & tmpFrequency3 & ■ ' , Respect = ■ ° & tim?Frequency4 & ■ • , Decis: 
m 1 ■ & tmpFrequency5 fie _ 

■ 1 , satisfaction = ■ ° & tmpSatisfaction & 0 • , Activity = ■ ■ & tmpActivzty & _ 
° 1 , Social » 1 n & tmpFrequencyTwo & B 1 , Functioning = ' " & tmpEf f ect & _ 

■ * , EndDatel = • 0 & EndDatel & . • # WHERE ConsumerlD = " & CustomerlD & ° AND Agei 
, sa 1 u & AgencyCode & _ 

■ 1 AND Episode = " & Episode & n AND CaseNumber = • " & CaseNuihber & " ' " 

End If 

cmdSave . Enabled = False 

MsgBox "End of Episode QA successfully saved!", vbOKOnly, "Save" 

Exit Sub 

errSave: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 
End Sub 

Private Sub Form_Jjoad() i 

txtCaseNumber . Text = CaseNumber b 
txtEpisode.Text = Episode 

txtConsumerName . Text « FirstName & ■ " & LastName 
txtPhoneNumber = PhoneNo 

AgencyName * f rmMainMenu . txtAgencyName 

lblAppointments . Caption = "The following questions are regarding ° & AgencyName & " services 
eneral. Were your appointments made quickly?" 

lblNeeds. Caption •» "Did the " & AgencyName & " staff understand your needs?" 

IblDecisions. Caption = "How often were you involved in decisions about the services you recei 
at " &" AgencyName & °? " 

lblSatisfied. Caption = "Overall, how satisfied were you with ■ & AgencyName & " services? Wo 
you say you were? ■ 

lblFunctioning. Caption = "How much have n & AgencyName & " services affected your ability to 
tion independently?" 

LoadControlsItems cboStaffs, False 
LoadControlsItems cboFrequencyl * True 
LoadControlsItems cboSatisf action. False 
LoadControlsItems cboActivity, False 
LoadControlsItems cboFrequency2 , False 
LoadControlsItems cboEffect, False 

Set rstQA = New Recordset 

r s tQA. Cur sorLoca tion = adUseClient 

rstQA. Open "SELECT * FROM QA WHERE Consumerld = ■ & CustomerlD & " AND Episode = " & Episode 
" AND Agency = 10 & AgencyCode & "' AND CaseNumber- = ■" & CaseNumber & ■ ' B , cnn, 
penDynamic, adLockOptimistic 

With rstQA 

If Not (.EOF And .BOF) Then 
.MoveFirst 

LoadDataToControls rstQA, txtParticipantNumber, False 

If ! [InterviewDate] - "12:00*00 PM" Or Trim( ! [InterviewDate] & vbNullString = nn ) Then 

txtlnterviewDate = " ■ 
Else 

txtlnterviewDate = \ [InterviewDate] 
End If 

LoadDataToControls rstQA, cboStaffs, False 
LoadDataToControls rstQA, cboFrequencyl, True 
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LoadDataToControls. rstQA, cboSatisfaction, False 
LoadDataToControls rstQA, cboActivity, False 
LoadDataToControls rstQA, cboFrequency2 , False 
LoadDataToControls rstQA, cboEffect, False 

If ![EridDatel] = "12:00:00 FM» Or Not IsDate < i [EndDatel] ) Then 

txtEndDatel = n " 

cmdOverallScore. Enabled = False 
Else 

. txtEndDatel = ! [EndDatel] 
End If 

if ! [EndDatel] <> "12:00:00 PM n Or IsDate (![ EndDatel ] ) Then 

cmdSave. Enabled = False 

cmdOverallScore. Enabled = True 
End If 
End If 

. Bid With . - 

End Sub 

Private Sub FornuUnload (Cancel As Integer) 
* rstQA. Close 
End Sub 



i 



It 
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Option Explicit 

Public IsNewRecord As Boolean 

Private rstlntervention As ADODB . Recordset 

Private InterventionSeq As Long 

Private Sub cboExtent_|CeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboExtent( Index) .List Index = -1 
End If 
End Sub 

Private Sub cmdClose__Click() / 
Unload Me 

Set rstlntervention = Nothing 
End Sub 

Private Sub cmdSave__Click< ) 
Dim x As Integer 
Dim Learning As String 
Dim Techniques As String 
Dim Responsibility As String 
Dim Realistic As String 

On Error GoTo errSave 

For x = 0 To cboExtent .Count 1 

If cboExtent(x) .Listlndex = -1 Then „. 

MsgBox "Please answer all questions to save the report" , vbOKOnly, "Save 
cboExtent (x) . SetFocus 
Exit Sub 
End If 
Next 

Learning = cboExtent (0) .It emData (cboExtent (0) .Listlndex) 
Techniques = cboExtent (1) • I temData (cboExtent (1) .Listlndex) 
Responsibility ■ cboExtent (2) . I temData (cboExtent <2) .Listlndex) 
Realistic = cboExtent (3) .ItemData (cboExtent (3) .Listlndex) 

cnn. Execute • UPDATE Interventions SET LearningProcess *= & Learning & " ' , ■ & _ 
° Techniques = 1 n & Techniques & " 1 , n & _ 

■ Responsibility = ■ ■ & Responsibility & n ' , ■ & _ 

■ Realistic = '" & Realistic & n, "& _ 
■ WHERE Consuroerld = ° & CustomerlD & _ 

AND Agency = 1 n & AgencyCode & u • n & _ 
AND CaseNumber = ■ ■ & CaseNumber &"'"&_ 

AND InterventionID = 1 " & f rmlnterventionl . InterventionCode & &- - 

" * AND mterventionSequence = ■ & interventionSeq 

MsgBox "Successfully Saved!", vbOKOnly, "EndOf Service" 
Exit Sub 

errSave * * 
MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 

End Sub 

private Sub Form_Load() 

txtConsumerName.Text * f rmlnterventionl . txtFirstName & » - & frmlnterventionl . txtLastName 
txtCaseNumber.Text = f rmlnterventionl . txtCaseNumber 
txtEpisode.Text = f rmlnterventionl. txtEpisode 
txtlntervention = frmlnterventionl. txtlntervent ion 
InterventionSeq = f rmlnterventionl . SequenceNo 

LoadControlsI terns cboExtent, True 

Set rstlntervention = New ADODB . Recordset 

. rstlntervention. Open "SELECT LearningProcess, Techniques ; Responsibility, Realistic" & _ 

■ FROM interventions WHERE Consumer Id - & CustomerlD & 
- AND Agency = • - & AgencyCode & " 1 AND CaseNumber = • ■ & CaseNumber & 
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■ AND Interventions « ' 0 & f ruilnterventionl . InterventionCode & & 

■ AND InterventionSequence = ° & InterventionSeq, cnn, adOpenDynamic , adl 

Optimistic 

LoadbataToControls rstlntervention, cboExtent, True 

rstlntervention . Close 
End Sub 
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Option Explicit 
Public IsNewRecord As Boolean 
Public IsFileDateChecked As Boolean 
Private rstEyeData As ADODB . Recordset 

Private Sub cboAcuity_JCeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboAcuity (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboAcuitySource_KeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

* cboAcuitySource( Index) .Listlndex = -1 
End If 
End Sub- 
Private Sub cboDiagnosis__Change (Index As Integer) 
Dim j As Integer 

If lsNumeric(Trim(cboDiagnosis(Index) t ,Text) ) And Len( Trim (cboDiagnosis (Index) .Text) ) = 3 Then 
For j = 27 To UBound(DiagnosisArray) 

If Trim(cboDiagnosis (Index) .Text) <= Mid ( Diagnosis Array (j ) , 1, 3) Then 
cboDiagnosis (Index) .Listlndex - j 

Exit Sub , 
End If 
Next 

Elself Trim (cboDiagnosis (Index) .Text) <> ' un And Len (Trim (cboDiagnosis (Index) .Text) ) = 1 Then 
If (Asc (Trim( cboDiagnosis ( Index) .Text) ) > 64 And Asc (Trim( cboDiagnosis (Index) .Text) ) < 91) 

(Asc (Trim(cboDiagnosis (Index) ..Text) ) > 96 And Asc (Trim (cboDiagnosis (Index) .Text ) ) < 12 
For j = 0 To 24 

'"if Asc (UCaselTrim(cboDiagnosis (Index) .Text) ) ) <= Asc(Mid(DiagnosisString( j ) , 1, 1) 



Then 
hen 



cboDiagnosis (Index) .Listlndex = j 
Exit Sub 
End If 

Next 
End If 
End If 
End Sub 

Private Sub cboDiagnosis_KeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then ■ 

cboDiagnosis (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboLengthAddress^KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboLengthAddress. Listlndex = -1 
End If . 
End Sub 

Private Sub cboStaf f sJKeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboStaffs. Listlndex = -1 
End If 
End Sub 

Private Sub cboVisualSour.ce_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboVisualSource. Listlndex = -1 
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Private Sub cmdClear_Click ( ) 

IsNewRecord = True 
clearData cboStaffs, False 
clearData txtEyeData, True 
clearData cboDiagnosis , True 
clearData IstHealthCondition, False 
clearData cboDiagnosis, True 
clearData cboAcuity, True 
clearData cboVisualSource, False 
clearData cboAcuitySource, True 
clearData cboLengthAddress, False 
clearData chkBox, True 
clearData txtGlass, True 
clearData cboVisualField, True 

cmdSave. Enabled = True 
End Sub 

Private Sub cmdClose_Click ( ) 
Unload Me 
End Sub 

Private Sub cmdNR>ctRecord_Click( ) 
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End If 
End Sub 



With rstEyeData 
.MoveNext 
If Not .EOF Then 

3*SS22S£S? .".iJSSSKSgSr*- „««I«^..«»bl.a = False 
cmdPreviousRecord. Enabled = True 
LoadDataToControls r,stEyeData, cboStaffs, False 
LoadDataToControls rstEyeData, txtEyeData, True 
LoadDataToControls rstEyeData, cboDiagnosxs, True 
LoadDataToControls rstEyeData, cboVi sua 1 Source, False 
LoadDataToControls rstEyeData, cboAcuitySource, True 
LoadDataToControls rstEyeData, cboAcuity, True 
LoadDataToControls rstEyeData, IstHealthCondition, False 
LoadDataToControls rstEyeData, cboLengthAddress, False 
LoadDataToControls rstEyeData, chkBox, True 
LoadDataToControls rstEyeData, txtGlass, True 
If. IsDate ( txtEyeData ( 0) ) Then 

cmdSave. Enabled = False 
Else 

cmdSave. Enabled = True 
End If 
End If 
.End With 
End Sub 

Private Sub cmdPreviousRecoroUClickO 



With rstEyeData 
.MovePrevious 
If Not .BOF Then 

txtCurrentRecord = .AbsolutePosition _ . p 

If AbsolutePosition = 1 Then cmdPreviousRecord . Enabled - False 



cmdNExtRecord. Enabled = True 
LoadDataToControls rstEyeData, 
LoadDataToControls rstEyeData, 
LoadDa taToContr ol s r s t EyeDa t a , 
LoadDataToControls rstEyeData, 
LoadDataToControls rstEyeData, 
LoadDataToControls. rstEyeData, 
LoadDataToControls rstEyeData, 
LoadDataToControls rstEyeData, 
LoadDataToControls r s tEyeData , 



cboStaf fs, False 
txtEyeData True 
cboDiagnosis, True 
cboVisualSource, False 
cboAcuitySource-, True 
cboAcuity, True 
IstHealthCondition, False 
cboLengthAddress , False 
chkBox, True 
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LoadDataToControls rstEyeData, txtGlass, True 
If lsDate(txtEyeData(0) ) Then 

cmdSave. Enabled = False 
Else 

cmdSave . Enabled = True 
End If 
End If 
End With 
End Sub 

Private Sub cmdSave_Click ( > * 
Dim colEyeData As New Collection 

On Error GoTo errSave 

colEyeData. Add cboStaffs 
colEyeData. Add cboDiagnosis 
colEyeData. Add cboVi sua 1 Source 
colEyeData. Add cboAcuity Source 
colEyeData. Add cboAcuity 
colEyeData. Add txtEyeData 
colEyeData. Add IstHealthCondition 
colEyeData. Add cboLengthAddress 

colEyeData. Add chkBox > 
colEyeData. Add txtGlass 

SaveDataToDB frmEyeData, rstEyeData, colEyeData, "0", False 'Call public function to 

e data to DB 

MsgBox "Successfully saved the Assessment information i " , vbOKOnly, "Save" 



IsNewRecord » False 

Set colEyeData = Nothing 

Exit Sub 

errSave : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 
End Sub 

Private Sub FornuLoadO 
Dim IndexNo As Integer 

Dim i As Integer, j As Integer, k As Integer 
On Err GoTo Errhandler 

txtFirstName = FirstName & n " & LastName 
txtAddress = Address 
txtCaseNumber = CaseNumber 

LoadControlsI terns cboStaffs, False 

Set rstEyeData =* New ADODB. Recordset 
rstEyeData.CursorliOCation = adUseClient 

rstEyeData. Open "Select Code, Description From Diagnosis" , cnn, adOpenForwardOnly, adLockRead 
With rstEyeData 
While Not .EOF 

cboDiagnosis (0) .Addltem ! (Description] 

cboDiagnosis (1) .Addltem "[Description] 

cboDiagnosis (0) . I temData (cboDiagnosis (0) .Newlndex) = .IndexNo . 
cboDiagnosis (1) .ItemData (cboDiagnosis (1) .Newlndex) = IndexNo 
DiagnosisArray( IndexNo) = 4 [Code] 

If IndexNo < 25 Then Diagnosi sSt ring (IndexNo) = ! [Description] 
IndexNo = IndexNo +*i 
. MoveNext 
Wend 

cboDiagnosis (0) .List Index = -1 

cboDiagnosis (l).Iiistlndex = -1 
End With 
rstEyeData . Close 
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StSS>ata°Open ? Select Code, Description From VisualField" , cnn f adOpenForwardOnly, adLockRead< 

iy 

With rstEyeData 
While Not .EOF 

cboVisualField(O) .Addltem i [Description] 
cboVisualField(l) .Addltem 1 [Description] 

cboVisualField(O) . ItemData (cboVisualField(O) .Newlndex) - IndexNo 

cboVisualField(l) . itemData (cboVisualField(l) .Newlndex) = IndexNo 

VisualFieldArray (IndexNo) = ! [Code] • 

IndexNO = IndexNo +1 

.MoveNext 
Wend 
End With 
rstEyeData . Close 

rstEyeData. Open "Select * From Eyedata Where ConsumerlD = ■ & CustomerlD & - And Agency = ' " & 

AgencyCode & • ' And CaseNumber = & CaseNumber & -Order By SequenceNo DESC, cnn, a 
penDynamic, adLockOptimistic 
With rstEyeData 

If Not (.BOF And .EOF) Then- 
txtRecor^No = .RecordCount 
txtCurrentRecord =1 

If .RecordCount > 1 Then. cmdNExt Re cord. Enabled = True 
LoadDataToControls rstEyeData, cboStaffs, False 
LoadDataToControls rstEyeData, txtEyeData, True 
LoadDataToControls rstEyeData, cboDiagnosis , True 
LoadDataToControls rstEyeData, .cboVisualSource, False 
LoadDataToControls rstEyeData, cboAcu ity Source . True 
LoadDataToControls rstEyeData, cboAcuity, True 
LoadDataToControls rstEyeData, IstHealthCondition, False 
LoadDataToControls rstEyeData, cboLengthAddress , False 
LoadDataToControls rstEyeData, chkBox, True 
LoadDataToControls rstEyeData, txtGlass, True 
If IsDate ( txtEyeData { 0) ) Then cmdSave . Enabled = False 
End If 
End With 

Exit Sub \ 

Errhandler: , B 
MsgBox. Err. Description, vbCritical + vbOKOnly, "Form Load 

End Sub 

Private Sub Form_Unload( Cancel As Integer) 

If rstEyeData. State = adStateOpen Then rstEyeData. Close 
Set rstEyeData = Nothing 
Set frmEyeData = Nothing 
End Sub 

Private Sub lstHealthCoridition_KeyUp(KeyCode As Integer, Shift As Integer) 
Dim i As Integer 

If KeyCode = vbKeyBack Then 

If IstHealthCondition. SelCount = 1 Then 

IstHealthCondition. Selected (IstHealthCondition .Listlndex) = False 
Elself IstHealthCondition. ListCount > 1 Then 

For i = IstHealthCondition. ListCount - 1 To' 0 Step -1 

If IstHealthCondition. Selected(i) Then . . 

IstHealthCondition. Selected(i) = False 
End If * 
Next 
End If 
End If 
End Sub 

Private Sub txtEyeData_Validate{ Index As Integer, Cancel As Boolean) ^ 



If Index = 0 Then 

If txtEyeData (index) <> n " Then. 
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" 2^J^iS2^£^. ? i*3S. vblnforn,a t ion ♦ vbOKOnly. -Assessment Date" 



txtEyeData ( Index) 
-Cancel = True 
End If 
Bid If 
End If 
End Sub 
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Option Explicit 

Private rst As ADODB . Recordset 'resordset object variable 

Private rstlLAssessment As ADODB. Recordset 

Public IsNewRecord As Boolean 

Private IsArrowKey As Integer 

Private IsGoalsC licked As Boolean 

Public XsFileDateChecked As Boolean 

Private IsVisuallnf oClicked As Boolean 

Private Sub cboAgencyServices_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode vbKeyBack Then 

cboAgencyServices ( Index) .List Index = -1 
End If 
End Sub 

Private Sub cboAgree_JCeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

. i 

If KeyCode = vbKeyBack Then 

cboAgree ( Index) t ListIndex = -1 
End If 
End Sub 

Private. Sub cboAgree^Lost Focus (Index As Integer) 



If CheckForTab Then 
If index = 1 Then 

tablLAssessment .Tab = 
El self Index = 19 Then 

tablLAssessment .Tab - 
Elself Index = 31 Then 

tablLAssessmeht .Tab = 
Elself index = 50 Then 

tabiliAssessment .Tab = 
Elself Index =73 Then 

tabiliAssessment .Tab = 
End If 
End If 
End Sub 

Private Sub cboBrailleLevel_KeyUp( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboBrailleLevel (Index) .Listlndex = -.1 
End If 
End. Sub 

Private Sub cboDif f iculty_JKeyUfc>( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboDif f iculty ( Index) .Listlndex = -1 
End- If 
End Sub 

Private Sub cboEnlargerName_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboEnlargerName. Listlndex = -1 ' 
End If 
End Sub 

Private. Sub cboEnlargerName_Los t Focus ( ) 

If CheckForTab Then * 

If cboEnlargerName.Listlndex <> 2 Then cboAgree (13) . SetFocus 
End If 
End Sub 



1 

2 
3 
5 
7 



Private Sub cboEquipment_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 



^nXLAssessment - 2 6Q»f3«5708 . Q ± 

If KeyCode = vbKeyBack Then 

cboiguipnient (Index) .Listlndex = -1 

End If 

'. " sub » Shi£t " I ° CM,t ' 

. End If 
End Sub 

Private Sub cboFactors_Click( Index As Integer) 

If isArrowKey > 0 Then Exit Sub 
If Index * 5 Then 

CountScore 

CountGoals . 
End If 

End Sub . 
Private Sub cbo P actors_Key D o W n(Xndex As Xnteger, KeyCode As Xnteger. Shift As integer) 

If KeyCode = ybKeyUp Then 

IsArrowKey * KeyCode a 
Elself KeyCode = vbKeyDown Then 

IsArrowKey =' KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode — 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey « KeyCode 
End If 
End Sub 



Private Sub cboFactors_LostFocus (Index As Integer) 



If CheckForTab Then 
If Index = 5 Then 
CountScore * 
CountGoals 
End If 
End If 



If IsArrowKey > 0* Then IsArrowKey = 0 

"IT. sub » ™— • " In " 3 - " 5 ~ 



End If 

" Sub cboObs.-eKssPO.se^OP.I^* AS integer. KevCoa. As sbl« As 

If KeyCode = vbKeyBack Then 

cboObserveResponse (Index) .Listlndex = -1 

End If 
End. Sub 

Private Sub cboObserveResponse_LostFocus (Index As Integer) . 
If CheckForTab Then 

If Index = 7 Then • 
tablLAssessment .Tab = 8 . 

End If 
End if 
End Sub 

Private Sub cbo*ating_KeyUp<xndex As Xnteger. KeyCode As xnteger. Shift As xnteger) 



f rmlLAssessment - 3 « ^ „ _ _ _ 

6-0431708 o,p.idL 

If KeyCode = vbKeyBack Then 

cboRating ( Index) . Lis tlndex = -1 
End If 
End Sub 

Private Sub cboRating_Lost Focus (Index As Integer) 

If CheckForTab Then 
If Index = 35 Then 

tablLAssessment .Tab = 4 
Elself Index =14 Then 

tablLAssessment .Tab = 6 
End If 
End If 
End Sub 

Private Sub cboReaderName__KeyUp (l^eyCode As Integer,. Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboReaderName .Lis tlndex = -1 
End If 
End Sub 

Private Sub cboReaderName__LostFocus ( ) 

If CheckForTab Then 

If cboReaderName. Listlndex <> 2 Then cboAgree{14) .SetFocus 
End If 
End Sub 

Private Sub cboServiceLevel_Click (Index As Integer) 

If IsArrowKey > 0 Then Exit Sub 

If. Index = 0 Then 

If cboServiceLevel (Index) .Listlndex = -1 Then 

txtilassessment (15) = an 
Else. 

cboTimeFrame.Listlndex « cboServiceLevel (index) .Listlndex - 1 
txtilassessment (15) = cboTimeFrame . Text 
End If 

tablLAssessment .Tab =10 
Call Count Goals 
End If 

End Sub 

Private Sub cboServiceLevel_KeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode . 
End If 
End Sub 

Private Sub cboServiceLevel_JCeyUp (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboServiceLevel (Index) .Listlndex = -1 
•End If. 
End Sub 



Private Sub cboServiceLevel_JLostFocus ( Index As Integer) 
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If Index = 0 Then 

If CheckForTab Then 

If cboServiceLevel (Index) .List Index » 0 Then 

txtilassessment (15) •? 00 
Else 

If cboServiceLevel ( Index) .Listlndex <> -1 Then 

cboTimeFrame . List Index = cboServiceLevel (Index) .List Index - 1 
txtilassessment (15) = cboTimeFrame . Text 

End If 
End If 

tablLAssessment .Tab - 10 
Call CountGoals 
cmdlns true tion ( 4 ) . SetFocus 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

♦Private Sub cboStaf f s_KeyUp (KeyCode As'.Integer, Shift As Integer) 

• If KeyCode * vbKeyBack Then 
cboStaffs. Listlndex = -1 
End If 
End Sub 

Private Sub cboYesNo_KeyUp (index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboYesNo( Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboYesNo_JLos tFocus (Index As Integer) 

If Index = 8 Then 

If CheckForTab Then 

• tablLAssessment .Tab = 9 
cboStrategiesLearning . SetFocus 

f rmlLAssessmeht . Caption - "Strategies Learning And Factors 
End If 
Elself Index » 10 Then 
If CheckForTab Then 

If cboYesNo (Index) .Listlndex » 1 Then cboYesNo (8) .SetFocus 

End If , 
Elself Index >= . 11 And Index <= 29 Then 
If CheckForTab Then 

If cboYesNo( Index) -Listlndex = 0 Then 

cboObserveResponse ( Index - 11) -SetFocus 
Else. * 
If Index = 11 Then 

txtilassessment (4) .SetFocus 

Else 

cboYesNo( Index - 1) .SetFocus 
End If • 
End If' 
• End If' 
Elself Index = 31 Then 
If CheckForTab Then 

If cboYesNo (31) .Listlndex <> 0 Then cboYesNo( 33) .SetFocus 

EncL If 
End If 
End Sub 

Private Sub cmdClear_Click ( ) 
IsNewRecord = True 
clearData txtilassessment,* True 
clearData chkGoals, True 
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clearData cboYesNo, True 

clearData cboAgree, True 

clearData cboExternal Services, True 

clearData cboAgencyServices, True . 

clearData cboEquipment, True 

clearData cboServiceLevel , True 

clearData cboFactors, True 

clearData cboStrategiesLeaming, False 

clearData cboObserveResponse, True 

clearData cboRating, True 

clearData cboDif f iculty , True 

clearData cboStaffs, False 

clearData cboLargerLVDeviceSize, True 

clearData cboBrailleLevel, True 

clearData cboEnlargerName, False 

clearData cboReaderName , False 

If rstlLAssessment -State = adStateOpen Then rstlLAssessment .Close 

rstlLAssessment. Open "Select * From ILAssessment Where ConsumerlD a " & CustomerlD & _ 

• And Agency = 1 " & AgencyCode & " ' And Episode = " & Episode & " And CaseNumber = » " & 
CaseNumber & ■ • And Intervention^ = ' 013 * Order By EntryDate, FinishDate ■ , cnn, _ 
adOpenKeyset, adLockOptimistic 

If Not rstlLAssessment . EOF Then rstlLAssessment .MoveFirst 

r 

cmdPrint .Enabled = False 
cmdSave. Enabled « True 
tablLAssessment .Tab =0 
End Sub 

Private Sub cmdClose__Click< ) 
Unload Me 
End Sub 

Private Sub cmdHistorical_Click{ ) 

IsVisuallnfoClicked = True 

f rmEyeData . Show ybModal 
End Sub 

Private Sub cmdInstruction_Click( Index As Integer) 
If Index = 0 Then 

MsgBox "If the answer to any consumer self-rating question is a 1 or 2: & CnrilJ) & _ 

Chr(lO) & " recommend training." & Chr{13) & Chr(10) & "If 3 or 4:" & Chr(13) & C3 

) & 

request a demonstration." & Chr(13) & Chr(10) & "If consumer doesn't not answer 
ndicates they are uninterested in performing a task:" _ 

& Chr(13) & Chr(10) & ". mark as R refused 0 , vbOKOnly, /Consumer Self-Rating. 

El self Index = 1 Then 

MsgBox. "Rating Scale - Obseerve and Train:" & Chr(13) & Chr(10) & _ 

1 = major problem, 10 = no problem, N/A, 1 = Refuses", vbOKOnly, "Rating Scale" 
Elself Index = 2 Then ^ ^ ^_ 

MsgBox "If problem affects safety, indicates problem/ inform consumer and record thexr re 
e", vbOKOnly 
Elself index = 3 Then 

End If 
End Sub 

Private Sub cmdNext_Click( ) 

If tablLAssessment. Tab = 10 Then . n . T . 

MsgBox "It is last page for Services Agreement already!", vblnformation + vbOKOnly, Next 

a * ' 

Else 

tablLAssessment. Tab = tablLAssessment . Tab +1 
frmlLAssessment. Caption = getTabCaption( tablLAssessment .Tab) 
End' If 
End Sub 
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Private Sub cmdWExtRecord.ClickC ) 
Dim tmpLong As Long 

With rstlLAssessment 
.MoveNext 

If .AbsblutePosition = 1 Then 

cmdPreviousRecord . Enabled = False 

cmdNExt Record . Enabled = True 
Elself .AbsolutePositibn < .RecordCount Then 

cmdPreviousRecord -Enabled = True 

cmdNExtRecdrd. Enabled = True 
Elself .RecordCount ^ .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNExtRecord. Enabled = False 
End If 



txtCurrentRecord = .AbsolutePosition 
txtSequencyNo = ! [AssessmentSequence] 

IioadDataToControls rstlLAssessment, cboStfategiesLearning, False 

. LoadDataToControls rstlLAssessment, cboStaffs, False 

LoadDataToControls rstlLAssessment, .txtilassessment , True 

IioadDataToControls rstlLAssessment , chkGoals, True 

LoadDataToControls rstlLAssessment, cboExternal Services, True 

LoadDataToControls rstlLAssessment, cboAgencyServices, True 

LoadDataToControls rstlLAssessinent, cboEquipment , True 

LoadDataToControls rstlLAssessinent, cboServiceLevel, True 

LoadDataToControls rstlLAssessment, cboObserveResponse , True 

LoadDataToControls rstlLAssessment, cboRating, True 

LoadDataToControls rstlLAssessment, cboDif f iculty, True • 
•LoadDataToControls rstlLAssessment, cboTimeFrame , False 

LoadDataToControls rstlLAssessment, cboFactors, True 

If rst. State = adStateQpen Then rst. Close 

r st. Open "Select * From ILAssessmentl Where ConsumerlD = 0 & Customer ID & ° And Agency = 1 

AgencyCode & ttl ! And. Episode = " & Episode & " And CaseNumber = & CaseNumber & _ 
° • And InterventionID = • 013 ■ And AssessmentSequence = " & ! [AssessmentSequence] & __ 
. ° Order By EntryDate", cnn, adOpenKeyset, adLockOptimistic 

LoadDataToControls rst, cboYesNo, True 

LoadDataToControls rst, cboAgree, True , 
rst. Close 

If ! [FinishDate] - "12:00:00 PM" Then 

cmdSave . Enabled = True 

cmdPrint . Enabled = False 
Else 

cmdSave . Enabled = False 
cmdPrint . Enabled = True 
End If 
End With 

tablLAssessment .Tab = 0 
txtCurrentRecord . SetFocus 
End Sub 

Private Sub cmdPrevious_Click() 

If tablLAssessment .Tab = 0 Then 

MsgBox "It is first page for Self Assessment already!", vblnf ormation +' vbOKOnly, "Previo* 
age" 
Else 

tablLAssessment. Tab « tablLAssessment .Tab - 1 

frmlLAssessment. Caption = getTabCaption { tablLAssessment .Tab) 
End If 
End Sub 

Private Sub cmdPreviousRecor6L.Click( ) 



With rstlLAssessment 
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.MovePrevious 

If .AbsolutePosition = 1 Then • 

cmdPreviousRecord. Enabled « False 

cmdNExtRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord- Enabled = True 

cmdNExtRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord . Enabled « True 

cmdNExtRecord. Enabled = False 
End If 

If ! [FiriishDate] = "12:00:00 PM" Then 

cmdSave . Enabled = True 

cmdPrint . Enabled = False 
Else 

cmdSave . Enabled = False 
cmdPrint . Enabled = True 
End If 
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txtCurrentRecord = .AbsolutePosition 
txtSequencyNo = ! [Assessment Sequence] 



LoadDataToControis rs t ILAsses sment , 
LoadDataToCon tr ol s r s t ILAsses sment , 
LoadDa t aToCon t r ol s r s t ILAss e s sment , 
IioadDataToControls rstlLAssessment, 
LoadDataToControis rst ILAsses sment , 
LoadDataToControis rs til/Assessment, 
LoadDataToControis rs tlliAssessment , 
LoadDataToControis rstlLAssessment, 
LoadDataToCon trol s r s t ILAsses sment , 
LoadDataToControis rstlLAssessment, 
LoadDataToControis rstlLAssessment , 
• LoadDataToControis rstlLAssessment , 



cboStrategiesLearning , False 
cboStaf f s , False 
txtilassessment. True 
chkGoa 1 s , True 
cboExternal Services, True 
cboAgency Service s , True 
cboEquipment , True 
cboServiceLevel , True 
cboObserveResponse, True 
cfcoRating, True 
cboDif f iculty, True 
cboTimeFrame , Fa 1 s e 



LoadDataToControis rstlLAssessment, cboFactors, True 
If rst. State = adStateOpen Then rst. Close 

rst. Open "Select * From losses smentl Where ConsumerlD = u & CustomerlD & ■ And Agency = 

AgencyCode & " 1 And Episode « n & Episode & " And CaseNumber = ' " & CaseNumber & _ 
■■ And InterventionID = ■ 013 • And. Asses sment Sequence = " & I [Asses sment Sequence) & _ 
"■ Order By EntryDate", cnn, adOpenKeyset, adLockOptimistic 

LoadDataToControis rst, cboYesNo, True 
^LoadDataToControis rst, cboAgree, True 1 * 

rst. Close 
End With 



txtCurrentRecord. SetFocus 
End Sub 

Private Sub cmdPrint_Click{ ) 
Dim i As Integer 

If Printers. Count = 0 Then 

MsgBox "No printer found associating with this computer. Please add a printer to it and tl 
ou can print out the Service agreement S " , — 

' vblnformation + vbOKOnly, "Printer" 
Else , 

If rst. State = adStateOpen Then rst. Close 

rst. Open "Select * from ILAgreement Where Assessment Sequence = " & txtSequencyNo , % cnn, ad( 
eyset, adLockOptimistic 

If Not rst.BOF Then 1 if there an existing report, delete it then create a new report 

rst. Delete 
End If 
rst .Close 

If rst. State * adStateOpen Then rst. Close 
rst. Open "Select * from ILAgreement Where AssessmentSequence » " & txtSequencyNo. cnn, ad< 
eyset, adLockOptimistic 
With rst 
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If .BOF And .EOF Then 
.AddNew 

! (CaseNumberl = txtCaseNumber 

! [Episode] = txtEpisode 

! [AssessmentSequence] = txtSequencyNo 

! [ConsumerName] = txtConsumerName 

I [AssessmentDate] = txtilassessment (0) 

I [AssessorName] = cboStaf f s.Text 

For i = 0 To chkGoals. Count - 1 

If chkGoals (i) .Value = 0 Then * 
.Fields (chkGoals (i) .Tag) = "No" 

Else 

.Fields(chkGoals(i).Tag) = "Yes" 
End If 
Next 

For i = 0 To 7 

. Fields ( cboYesNo ( i )- Tag) = cboYesNo ( i ). Text 

Next 



For i = 0 To cboEquipment. Count - 1 

. Fields (cboEquipment <i) .Tag) = cboEquipment ( x ) . Text 

Next 

For i = 0 To cboAgencyServices - Count - 1 . 

.Fields (cboAgencyServices(i) .Tag) = cboAgency Servxces ( i ) . Text 

Next 

For i * 0 To cboExternalServices. Count - 1 

.Fields (cboExternalServices(i) .Tag) = cboExternal Servxces (x) .Text 



Next 

. Fields ("TimeFrame") « cboTime Frame . Text 
.Update * 

End If 
End tilth 
■rst.Requery 

Set ilAgreement.DataSource « rst 
ILAgreement . PrintReport 
End If 
End Sub . 

Private Sub cmdSave_Click( ) 
Dim i As integer 

Dim colILAssessment As New Collectxon 
On Error GoTo errSave 

colIliAssessment .Add cboRating 
colILAssessment. Add txtilassessment 
colILAssessment .Add cboStrategiesLearnxng 
colILAssessment. Add cboStaffs 
colILAssessment .Add cboLargerLVDeviceSxze 
colILAssessment. Add cboEnlargerName 
colILAssessment. Add cboReaderName 
colILAssessment .Add cboBrailleLevel 
colILAssessment .Add chkGoals 
colILAssessment .Add cboExternalServices 
colILAssessment. Add cboAgencyServices 
colILAssessment. Add cboEquipment 
colILAssessment. Add cboServiceLeyel . 
colILAssessment. Add cboFactors 
colILAssessment .Add cboObserveResponse 
colILAssessment. Add cboDif f iculty 
colILAssessment. Add cboTimeFrame 



and the factors are there 
If cboStrategiesLeaming.Listlndex » -1 Then 
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tabllAssessment .Tab »• 9 

SSr-V^Sr^sIiect^nrof items from Strategy Learning, vblnformation ♦ vbOKOnl, 
"Strategy Learning 0 » 
Exit Sub 
End If 

For i « 0 To cboFac tors .Count - 1 

If cboFactors(i) .Listlndex = -1 Then 
tabll/Assessment -Tab - 9 

SSx'-V^naf to° S elect one of items from Factors!-, vblnformation ♦ vbOKOnly, >M 

Exit Sub 
End If 
Next 

End if 

If rstllAssessment. State = adStateOpen Then rstlLAssessment .Close 

rstllAssessment. Open -Select * From IIAssessment Where ConsumerlD - • & CustomerID& 
• - And Agency = & AgencyCode & "» And Episode = - & Episode & 0 And CaseNumber - & 

CastNumber And InterventionID = '013' Order By AssessmentSequence DESC ". cnn, _ 

adOpenKeyset, adLockOptimistic 

If saveDataToDB(f:rmIIAssessment f rstlliAssessment, colIlAssessment, "013", False) Then 
all public function to save data to DB , 

ILSequenceNo = rstllAssessment! [AssessmentSequence] 

rstllAssessment .Close 

For i « 1 To colIlAssessment. Count 

colIIiAssessment . Remove 1 
Next ' \ 

rstllAssessment. Open "Select * From ilAssessmentl Where ConsumerlD = ■ ^CustomerlD & • 
^ S ^' * AgencyCode & - And Episode = >.fi Episode & ■ And CaseNumber - ■■ & 
CaseNumber * »• And* InterventionID = '013' And AssessmentSequence = » & ILSequenceNo & . 
■ Order by AssessmentSequence DESC", cnn, adOpenKeyset, adLockOptimistic 

colIlAssessment .Add cboYesNo 

colILAssessment. Add cboAgree ann „ tt-iipO Then 

If SaveDataToDBtfrmllAssessment, rstllAssessment, colILAssessment, 013 , True; men 

S^SSE:S2 a -8«lect * From ^Assessment Where ConsumerlD = " &nd*Caa^totoer^-" • 
• And Agency = & AgencyCode & • • And Episode = " & Episode & And CaseNumber - 

CaseNumber & And InterventionID = '013* Order By AssessmentSequence DESC", cnn, _ 
adOpenKeyset, adLockOptimistic 

" MsgBox "Successfully saved the Assessment information!*!, vbOKOnly, "Save" 

If IsDate (txtilassessment (0 ) ) Then «- v ww*o,,Tn^<w>r-e & 

cnn. Execute "Update Interventions Set PreConsumer Score = ■• & txtConsumerScore & - 
"^ PreProviderScore - & txtProviderScore & ■' Where ConsumerlD - ■ & Customer 

■-And Agency = & AgencyCode & - And Episode = • & Episode & - And CaseNumber 

& - CaseNumber & ■ - And InterventionID = '013- And (EndDate = #12:00:00 PM# or EndDat 

NULL) 0 

cnn. Execute "UPDATE ^Assessment AS a INNER JOIN Interventions AS b ON (a.CaseNumbei 
.CaseNumber)-- ^ -Episode « b . E pisode) AND (a.ConsumerlD = b.ConsumerlD) SET a . Interventic 

uence = b. InterventionSequence 0 & — • ' r»a jc. «• and (b 1 

■ WHERE b. InterventionID = - 013 ' and b. CaseNumber = & CaseNumber & AND <n.i 

.te = #12:00:OOPM# OR b. EndDate IS NULb) " & _ 

■ AND a. InterventionSequence = 0° 

End If 



If IsNewRecord Then 

rstlLAssessment ..Reguery 

txtSequencyNo = rstlLAssessment I C Assessment Sequence J 
' End If 

IsNewRecord = . False 

Set colILAssessment = Nothing 
End If 
End If 
Exit Sub 

err Save: . 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 
End Sub 



Private Sub Form^ActivateC ) 

On Error GoTo Errhandler 

If IsVisuallnf oClicked Then Exit Sub 

txtConsumerName = FirstName & tt " & Iras t Name 

txtphone = PhoneNo 

txtAddre^s = Address 

txtCaseNumber = CaseNumber 

txtEpisode = Episode 

txtlntervention = "IL Assessment" 

Set rst = New ADODB. Recordset 1 create recordset object 

LoadControlsItems cboStaffs, False " 'Add every description from database to combobox 01 

tbox" 

Set rstllAssessment = New ADODB. Recordset 

rstlLAssessment.. CursorLocation = adUseClient , 

rstlLAssessment. Open "Select * From ILAssessment Where Consumer ID « » ^ Customer ID & _ 

p And Agency = ■ " £ AgencyCode & " 1 And Episode = 0 & Episode & ■ And CaseNumber « 1 » S 
CaseNumber & ■ • And Interventions = '013* Order By Asses smentSeguence DESC 0 , cnn, _ 
adQpenKeyset, adLockOptimistic 



With rstlLAssessment 

txtRecordNo « .RecordCount _ ^ . 

If Not {.EOF And .BOF) Then 'Have record for this client and load it tc 

m 

txtCurrentRecord = .AbsolutePosition 
txtSequencyNo = ! [Asses smentSeguence] 

LoadDataToControls rstlLAssessment, cboStrategiesLearning, False 
LoadDataToControls rstllAssessment, cboStaffs, False 
LoadDataToControls rstlLAssessment, txtilassessment. True 
LoadDataToControls rstlLAssessment, chkGoals, True 
LoadDataToControls rstlLAssessment, cboExternal Services , True 
LoadDataToControls rstlLAssessment, cboAgencyServices, True 
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With rstlLAssessment 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord -Enabled = False 
Else 

cmdPreviousRecord. Enabled = True 
. End If 

If .RecordCount = .AbsolutePosition Then 

cmdNExtRecord. Enabled = False 
Else 

cmdNExtRecord. Enabled = True 
End If 
.End If 
End With 
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LoadDataToControls rstlLAssessment, cboEquipment , True 
LoadDataToControls rstlLAssessment, cboServiceLevel, True 
LoadDataToControls rstlLAssessment, cboObserveResponse, True 
LoadDataToControls rstlLAssessment, cboRating., True 
LoadDataToControls rstlLAssessment, cboDif f iculty. True 
LoadDataToControls rstlLAssessment, cboLargerLVDeviceSize, True 
LoadDataToControls rstlLAssessment, cboBrailleLevel, True 
LoadDataToControls rstlLAssessment, cboEnlargerName , False 
LoadDataToControls rstlLAssessment, cboReaderName, False 
•LoadDataToControls rstlLAssessment, cboTimeFrame, False - 
LoadDataToControls rstlLAssessment, cboFactors, True 

rst.Qpen "Select '* From ILAssessmentl Where ConsumerlD = " & CustomeriD & " And Agency = 
& _ . 

AgencyCode & " ' And Episode = ■ & Episode & n And CaseNumber = 1 B & CaseNumber & _ 
01 And InterventionID = '013' And Assessment Sequence » ■ & J {Assessment Sequence] & _ 
" Order By Assessment Sequence 0 , cnn, adppenKeyset, adLockOptimistic 
With rst 

If Not { .BOF And -EOF) Then 

LoadDataToControls rst," cboYesNo, True 
LoadDataToControls rst, cboAgree, True 
End If 
End With 

If .RecordCount <- 1 Then 

cmdNExtRecord. Enabled ■ False 

cmdPreviousRecord. Enabled *= False 
Blself -RecordCount >= 2 Then 

cmdPreviousRecord- Enabled = False 

cmdNExtRecord. Enabled « True 
End If 

If J [FinishDate] <> "12:00:00 PM° And IsDate ( ! [FinishDate] ) Then 

cmdSave - Enabled = False 

cmdPrint . Enabled = True 

cmdClear . Enabled = True 
End If 
Else 

cmdNExtRecord. Enabled = False 
cmdPreviousRecord. Enabled =' False 
txtCurrentRecord =0 
End If 
End With 

tablLAssessment .Tab = 0 
txtConsumerName . SetFocus 
Exit Sub 

Errhandler : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 



Private* Sub Form_Unload( Cancel As Integer) 
Dim response As Integer 



If IsFileDateChecked Then 

If rst. State = adStateOpen Then rst. Close 

If rstlLAssessment .State = adStateOpen Then* rstlLAssessment .Close 
Set rst ^ Nothing * 
Set rstlLAssessment = Nothing - 
tablLAssessment .Tab =0 
Set frmlLAssessment = Nothing 
Else 

If Trim(txtilassessment (0) ) « " " And cmdSave. Enabled Then 

response = MsgBox("Have you finished il Assessment ?", vbQuestion + vbYesNo, "File Date" 
If response = vbYes Then 

MsgBox "Please enter the File Date vblnformation + vbOKOnly, "File Date" 

txtilassessment (0) .SetFocus 

Cancel = True 
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Else 



If rst. State = adStateOpen Then rst. Close 

If rstlLAssessment. State = adStateOpen Then rstlLAssessment . Close 



Set rst =■ Nothing 
Set rstlLAssessment = Nothing 
tablLAssessment.Tab = 0 
Set frralLAssessment » Nothing 
End If 

Elself IsDate{Trim(txtilassessment(0))) And ' cmdSave . Enabled Then 

response = MsgBox ("Are you sure you finished the IL Assessment?", vbQuestion + vbYesNo, 
le Date") 

If response = vbYes Then . • „ . 

MsgBox "Please click Save button to save the assessment information", vblnformation + 

OKOnly, "Pile Date" 

cmdSave i SetFocus 
Elself cmdSave . Enabled » True Then 

txtilassessment.(O) = " * 
End If 

Elself. IsDate(Trim(txtilassessment(0) )) Arid Not cmdSave . Enabled Then 
If rst. State = adStateOpen Then rst. Close 

If rstlLAssessment. State = adStateOpen Then rstlLAssessment . Close 

Set rst = Nothing 

Set rstlLAssessment = Nothing 

tablLAssessment.Tab =0 

Set frmlLAssessment = Nothing 

End If 
End If 
End Sub 

Private Sub CountGoalsO , 
Dim i As Integer 

For i = 0 To cboAgree. Count 1 
Select Case i 
Case 0 To 19 

If cboAgree (i) .Text = "Yes" Then chkGoals(O) =1 
Case 20 To 42 

If cboAgree (i) .Text = "Yes" Then chkGoals(l) = 1 
Case 43 To 50 

If cboAgree (i). Text = "Yes" Then chkGoals{2) =1 
Case 51 To 60 

If cboAgree (i) .Text = "Yes" Then chkGoals(3) =1 
Case 61 To 73 

If cboAgree (i) .Text = "Yes" Then chkGoals<4) = 1 * 
End Select 
Next 
End Sub 

Private Sub CountScoreO 
Dim i As Integer. 
Dim tmpValue As integer 
Dim taskAAs Single 
Dim taskB As Single 
Dim taskD As Single 
Dim taskE As Single 
Dim. avgScore As Single 

If cboStrategiesLearning.Listlndex = -1 Then 
tablLAssessment.Tab = 9 

cboStrategiesLearning . SetFocus \ a .. „ . „^ ni< 

MsgBox "You have to select one of items from Strategy for Learningl", vblnformation + vdO* 

, "Strategy Learning" 

Exit Sub 
End If 

For i = 0 To cboFac tors. Count - 1 

If cboFactors(i) .Listlndex = -1 Then 
tablLAssessment.Tab = 9 

S3S t ^Si 1 hiiI t 5 C SSl«ct one of items from Factors!", vblnformation - vbOKOnly.. "Pact 



For i = 0 To cboDif f iculty. Count - 1 'count the score for task A - self assessment items 

If cboDifficulty(i) .Listlndex = -1 Then 

taskA = taskA + 4 . 
Else 

tmpValue - cboDif ficulty(i) . ItemData(cboDiff iculty (i) -List Index) 

If tmpValue = 5 Then 'User select "Refused" » count 0 for this item 

taskA = taskA + 0 
Else 

, taskA = taskA + tmpValue 
End If 
End If 
Next 

tmpValue = 0 

For i = 0 To cboRating. Count - 1 1 provider rated items 

If (i = 13 Or i = 14 Or i = 25 Or i = 70 Or i = 90 Or i = 91) Then GoTo Here 
hese 

If (i >= 34 And i <= 46) Then GoTo Here 

ngs 

If cboRating(i) .Listlndex = -1 Then 'user doesn't select one, count 10 for this item 

taskB = taskB +10 
Else 

tmpValue = cboRating < i) . I temData (cboRating (i) -List Index) 

If tmpValue = 11 Then 'User select "N/A° , count 10 for this item 

taskB = taskB +10 
Else* 

taskB * taskB + tmpValue 
E£id If 
End If 

Here : 
Next 

taskD * cboStrategiesLeaming - 1 temData (cboStrategiesLeaming. Lis tlndex) 
tmpValue = 0 

For i = 0 To cboFactors. Count - % 

Select Case cboFactors (i). I temData (cboFactors (i) .Listlndex) 

Case -3: tmpValue = 120 

Case -2: tmpValue = 110 

Case -1: tmpValue » 105 

Case 0: tmpValue =91 

Case 1: tmpValue =80 

Case 2: tmpValue =60 

Case 3: tmpValue =25 
End Select 

"taskE = taskE + tmpValue 
Next 

txtConsumerScore = taskA *-2.5 Self Assessment Score. 

txtProviderScore = taskB * 0.1 1 Provider Score 

avgScore ■ ((taskA * 2.5) + (taskB * 0.1) + taskD + (taskE / 6)) / 4 

txtilassessment(2) = CLng (avgScore) 
If avgScore > 100 Then avgScore = 100 
txtilassessment(lO) = Format ( taskA * 2.5, "##") 
txtilassessment (11) = Format (( taskB * 100) / 740, "##") 
txtilassessment(12) = Format (taskD, "##*) 
txtilassessment(13) = Format (taskE / 6, n ## rt ) 
txtilassessment(14) = Format (avgScore, B ##") 

Select Case CLng (avgScore) 

Case 0 To 60: txtilassessment (1) = "Level 3° 

Case 61 To 80: txtilassessment (1) = "Level 2° 

Case 81 To 90: txtilassessment (1). = "Level 1° 



frmlLAssessment - 13 

Exit Sub 
End If 
Next 



1 Do not com 
• provider : 
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Case 91 To 100: txtil assessment (1) = "No Service Needed 8 
End Select 
End Sub 

Private Function getTabCaption (tablndex As Integer) As String 

Select Case tablndex 
Case 0 

getTabCaption = "Media for Reading /Writing 1° 
Case 1 

getTabCaption - "Media for Reading /Writing 2" 
Case 2 

getTabCaption == "Organization & Differentiating Skill 1° 
Case. 3 * 

getTabCaption = "Organization & Differentiating Skill 2° 
Case 4 

getTabCaption = "Measurement" 
Case 5 ( 

getTabCaption = "Scanning Skills" 
Case 6 

getTabCaption = "Safety & Cooking" 
Case 7 

getTabCaption = "Observe And Inform Consumer 1" 
Case 8 

getTabCaption = "Observe And Inform Consumer 2" 
Case 9 

. getTabCaption = "Learning Strategy and Factors" 
Case 10 

getTabCaption = "IL Services Agreement" 
End Select 

End Function 

■i 

Private Sub tabILAssessment_Click(PreviousTab As Integer) 
Dim i As Integer 

If PreviousTab = 9 Then 

For i = 0 To chkGoals .Count - 1 

chkGoals(i) .Value =0 
Next 

If cboServiceLevel(O) .Listlndex = -*1 Then 

cboTimeFrame. Listlndex = -1 
Else 

cboTimeFrame. Listlndex = cboServiceLevel (0) .Listlndex - 1 
End If 

End If 

If tablLAssessment .Tab = 0 Then 

frmlLAssessment. Caption = "Media for Reading/ Writing" 

cboStaf f s . SetFocus 
Elself tablLAssessment .Tab = 1 Then 

frmlLAssessment .Caption = "Media for Reading/Writing" 

cboRating(87) .SetFocus 
Elself tablLAssessment .Tab - 2 Then 

frmlLAssessment .Caption = "Organization & Differentiating Skill" 

cboDiff iculty ( 7 ) , SetFocus 
Elself tablLAssessment .Tab = 3 Then 

frmlLAssessment -Caption = "Organization & Differentiating Skill" 

cboRating(57) .SetFocus 
Elself tablLAssessment .Tab = 4 Then 

frmlLAssessment -Caption = "Measurement" 

cboDifficulty<6) .SetFocus 
Elself tablLAssessment .Tab » 5 Then 

frmlLAssessment .Caption = "Scanning Skills" 

cboDiff iculty (3) .SetFocus 
Elself tablLAssessment. Tab = 6 Then 

frmlLAssessment. Caption = "Safety & Cooking" 
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cboDifficulty(l) .SetFocus 
Elself tablLAssessment .Tab = 7 Then 

fnnlLAssessment . Caption = "Observe And Inform Consumer" 

cmdln struct ion (2) .SetFocus 
Elself tablLAssessment .Tab = 8 Then 

f rmlliAssessment . Caption = "Observe And Inform Consumer* 

cboYesNo ( 17 ) . SetFocus ■ 
Elself tablLAssessment . Tab = 9 Then 

fnnlLAssessment .Caption = "Learning strategy and Factors" 

cboStrategieSLearning. SetFocus 
Elself tablLAssessment .Tab = 10 Then 

Count Goals • 

If Not IsGoalsClicked Then. 

f rmlliAssessment .Caption = "IL Services Agreement" 
cmdlnstruction(4) .SetFocus 
End If 
End If 
End Sub 

Private Sub txtCurrentRecordJjOstFocus ( ) 

If CheckForTab Then 
cboStaff s . SetFocus 

frmlLAssessment. Caption = "Self Assessment" 
End If 
End Sub 

Private Sub txt i lasses sment_Validate (Index As Integer, Cancel As Boolean) 

If Index = 0 Or Index » 7 Or Index = 8 Then 
If Trim { txt ilassessment (Index) ) <> Then 

If Not IsDate (Trim (txt ilassessment (Index) ) ) Then 



MsgBox "Please enter date into this field vblnf ormation + vbOKOnly, "Date" 
txt ilassessment (Index) = * " 
Cancel = True. 



End If 



End If 
End If 
End Sub 



\ 
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Option Explicit 

Private tmpPosition As Long 

Private rst As ADODB . Recordset 

Private rstlnterventions As ADODB . Recordset 

Private rsScores As ADODB . Recordset 

Private rsScores2 As ADODB. Recordset 

Public SeguenceNo As Dong 

Public InterventionCode As String 

Private PreSelf Score As Integer 

Private PreProvider Score As integer 

Private PreServiceScore As Single 

Private PostServiceScore As Single 

Private Functional As Double 



Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdEndOfService_Click() 
frmEndOf Service. Show vbModal 
End Sub 

Private Sub cmdNext_Click( ) 
Dim i As Integer 



If Trim (txtEndDate) = 



Then SavelnfoToDB 



With rstlnterventions 
. MoveNext 

If Not (.EOF) Then 

txtCounter = .AbsolutePosition 
InterventionCode = ! t Interventional 
txtStartDate = ! (StartDateJ 

If ! [EndDate] = "12:00:00 PM n Or Trim( ! [EndDate] & vbNullString) 

txtEndDate = Dn 

cmdSave. Enabled = Trjue 
Else 

txtEndDate = ! [EndDate] 
cmdSave . Enabled = False 
End if 



Then 



IioadDataToControls rstlnterventions, cboStaffs. False 
LoadDataToControls rstlnterventions, cboIntervehtionOutcome, False 
I/oadDataToControls rstlnterventions, txtPreserviceScore , False 
IioadDataToControls rstlnterventions,. txtPostServiceScore, False 
LoadDataToControls rstlnterventions, txtFunctionalChange, False 

If Trim (! [OutcomeNarrative] & vbNullString) = 11 Or ! [OutcomeNarrative] = Null Then 

txtOutcomeNarrative = ■» ■ 
Else 

txtOutcomeNarrative = ! [OutcomeNarrative] 
End If 

tmpPosition = .AbsolutePosition 
SeguenceNo = J [ In t erven tionSequence] 
InterventionCode = ! [InterventionlD] 

If rst. State = adStateppen Then rst. Close . 

rst. Open "Select Description From InterventionCodes Where Code - 1 n & InterventionCode 

cnn, adOpenForwardOnly, adI*ockReadOnly 
txt Intervention a rst ! [Description] 
txt Intervention . Set'Focus 



If .RecordCount > 1 Then 

If .AbsolutePosition - 1 Then 
cmdPrevious . Enabled = False 
cmdNext . Enabled = True 
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Elself .AbsolutePosition < .RecordCount Then 
cmdPrevious . Enabled = True 
cmdNext . Enabled - True 
Elself .RecordCount = .AbsolutePosition Then 
cmdPrevious . Enabled = True 
cmdNext -Enabled = False 
End If 
End If 
End If 
End With 

End Sub 

Private Sub cmdPrevious_Click( ) 

Dim i* As Integer • 
If Trim(txtEndDate) = on Then SavelnfoToDB 

With rstlnterventions 
.MovePrevious 
. If Not (.BOF) Then 

txtCounter = .AbsolutePosxtxon 
InterventionCode = ! [InterventionID] 
txtStartDate = ! [StartDate] 

If ![EndDate] = "12:00:00 PM« Or Trim< ! [EndDate] & vbNullString) = " Then 

txtEndDate = on 

cmdSave. Enabled = True • • 
Else 

txtEndDate = ! [EndDate] 
cmdSave. Enabled. = False 
End If 

LoadDataToControls rstlnterventions, cboStaffs, False 
LoadDataToControls rstlnterventions, cbo In t erven txonOut come. False 
LoadDataToControls rstlnterventions, txtPreservxceScore. False 
LoadDataToControls rstlnterventions, txtPostServxceScore, False 
LoadDataToControls rstlnterventions, txtFunctxonalChange, False 

If TrimdtOutcomeNarrative] 6 vbNullString) = Or ! [OutcomeNarrative] = Null Then 
txtOutcomeNarrative = ■ ■ 
» Else 

txtOutcomeNarrative = ! [OutcomeNarrative] 
End If 

SequenceNo = ! [ In t erven tionSequence] 
InterventionCode = ! [InterventionID] 

If rst. State * adStateOpen Then rst. Close 

rst. Open "Select Description From InterventxonCodes Where Code 

n 

~ cnn, adOpenForwardOnlyi adLockReadOnly 
txtlntervention » rst ! [Description] 

txtlntervention . SetFocus 
If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 
cmdPrevious - Enabled = False 
cmdNext . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPrevious. Enabled == True 
cmdNext . Enabled = True 
Elself -RecordCount = .AbsolutePosition Then 
cmdPrevious . Enabled = True 
cmdNext . Enabled = False 
End If 
End If 
/ End If 
End With 



& InterventionCode & 
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End Sub 

Private Sub cmdRef erral_Click() 

f rmRef erral . Show vbModal 
End Sub 

Private Sub cmdSave_Click{ ) 

SavelnfoToDB 

•cmdNext. Enabled = True 

If (IsDate(txtEndDate) = True) Then 

CalculateScore 
End If 

MsgBox "Successfully save the information! ■ , vbOKOnly, "Save Info" 
End Sub 

Private Sub cmdVisits_Click() 
'Dim rst As New ADODB. Recordset 
'Dim SQLStr As String 

•If (InterventionCode = n 014" Or InterventionCode = "013" Or InterventionCode » "010" Or Inter 
tionCode = "050" Or InterventionCode = "160") Then 
•Select Case InterventionCode 
'Case "010" 

'SQLStr = "Select Agency From SocialAssessment Where ConsumerID=" & .CustomerlD & _ * 
" And Agency = 1 0 & AgencyCode & n ■ Arid CaseNumber = 1 " & CaseNumber & _ 
"' And Episode = " & CLng ( Trim (txt Episode) ) 

'Case "014° 

1 SQLStr - "Select Agency From Mobil ityAssessments Where ConsumerlD^" & CustomerlD & _ 
" And Agency = ' n & AgencyCode & " ' And CaseNumber = ' " & CaseNumber & _ 
■» And Episode = ° & CLng (Trim ( txt Epi sode ) ) 

'Case "013" 

•SQLStr « "Select Agency From ILAssessment Where Consumer I.D=" & CustomerlD & _ 

" And Agency = * " & AgencyCode & " • And CaseNumber = ' " & CaseNumber & _ 
"• And Episode » " & CLng (Trim (txt Epi sode ) ) 

'Case "050" 

'SQLStr = "Select Agency From EmploymentAssessment Where ConsumerID=" & CustomerlD & 
" And Agency — 1 ■ & AgencyCode & " 1 And CaseNumber = ' " & CaseNumber & _ 
"• And Episode = " & CLng (Trim (txt Epi sode ) ) 

'Case "160" 

•SQLStr = "Select Agency From ComputerAssessment Where ConsumerID=" & CustomerlD & _ 
" And Agency =*.'"& AgencyCode & "' And CaseNumber = • " & CaseNumber & _ 
"• And Episode = w & CLng (Trim (txt Epi sode) ) 

'End Select 
•With rst 

• .Open SQLStr, cnn, adOpenForwardOnly, adLockReadOnly 

If •togBox^"piease T cre^ an Assessment for the selected intervention before making vis: 

■ecords!", _ . t 

vbOKOnly + vblnformation, "Visits" 

* Else 

•frmVisitsl.Show vbModal 
'End If 
•End With, 
•rst. Close 
•Set rst -Nothing 
•Else • 

frmVisitsl.Show vbModal 
•End If 

End Sub 

Private Sub FonruLoadO 
Dim i As Integer 



On Error GoTo Errhandler 
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liOadControlsItems cboStaf fs. False 
LoadControlsItems cboInterventionOutcome, False 

txtFirstName = FirstName 
txtLastName = LastName 
txtCaseNumber = CaseNumber 
. txtEpisode = Episode 

Set rst = New ADODB. Recordset 

rst .Cursor-Location = adUseClient 

Set rstlnterventions = New ADODB . Recordset 

rSft^^ Staffname, StartDate, EndDate, 

- InterventionOutcome, OutcomeNarrative. PreServiceScore, PostServiceScore, FunctibnalChai 

From Interventions Where ConsumerlDs" & _ t - 

CustomerlD & ■ And Agency =» '» & AgencyCode & - - And CaseNumber = ■" & CaseNumber & And 1 

S ° d CLng^im(txtEpisode) ) & " Order By Interventions equence DESC , cnn, adOpenDynamic , adLockQ 
mistic 

With rstlnterventions 

If Not (.BOF And . EOF) Then 

txtCounter = .AbsolutePosition 
InterventionCode = I { In t erven tionID] 

txtStartDate = 2 [StartDate] . 
LoadDataToControls rstlnterventions, cboStaffs, False f 
LoadDataToControls rstlnterventions, cboInterventionOutcome, False 
LoadDataToControls rstlnterventions, txtPreserviceScore, False 
LoadDataToControls rstlnterventions, txtPostServiceScore, False 
lK>adDataToControls rstlnterventions, txtFunctionalChange, False 

If I [EndDate] = "12:00:00 PM" Or Trim( ! [EndDate] & vbNullString) - ■■ Then 

txtEndDate ■ *" 

cmdSave. Enabled = True 
Else 

txtEndDate = S [EndDate] 
cmdSave. Enabled = False 
End If 

If Trim(! [OutcomeNarrative 1 & vbNullString) = *■ Or ! [OutcomeNarrative] = «ull Then 

txtOutcomeNarrative = Bn 
Else. 

txtOutcomeNarrative = ! [OutcomeNarrative] 
End If 

tmpPosition « .AbsolutePosition 
SequenceNo = I [InterventionSequence] 
InterventionCode = ! (Interventions] 

• txtPostProviderScore « ! [postProvider score] & vbNullString 

• txtPostConsumerScore = ! [postConsumer score] & % vbNullString 

rst. Open "Select Description From InterventionCodes Where Code = & InterventionCode 

o 

cnn, adOpenForwardOnly, adLockReadOnly 
txtlntervention = rst I [Description] 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 
" cmdPrevious . Enabled - False 

cmdNext . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPrevious .Enabled = True 

cmdNext . Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPrevious . Enabled = True 

cmdNext. Enabled = False 
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If rst, State = adStateOpen Then rst. Close* 
txtTotal = rst Interventions. RecordCount 
Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vblnformation, "Form Load" 
End Sub 

Private Sub Form_Unload (Cancel As Integer) 
'Dim response As Integer 

■response = MsgBox ( "Would you like save the Intervention information ?", vbQuestion + vbYesNo, 
lose") 

• If response = vbYes Then 

•MsgBox "Please use Save button to save it!", vblnformation + vbOKOnly, "Close 8 

•Cancel - True 
•Else 

If rst. State = adStateOpen Then rst. Close 

rstlntervent ions .Close 

Set rst = Nothing 

Set rstlntervent ions = Nothing 

Set frmlnterventionl = Nothing 

•End If 
End Sub 

Private Sub txtEndDate_Valida'te (Cancel As Boolean) 

If Trim (txtEndDate) = u " Then 

Cancel = False 
Elself Not IsDate (txtEndDate) Then 

MsgBox "Please enter date in this field!", vblnformation + vbOKOnly, "Date Validate" 

Cancel » True 
End If 
End Sub 

Private Sub Savelnf 0T0DB ( ) 
Dim tmpDate As Date 
Dim tmpStr As String 
Dim tmpstrl As String 
Dim tmpstr2 As String 

If cboStaffs.Listlndex = -1 Then 

tmpStr = "« 
Else - 

tmpStr = cboStaffs.ItemData(cboStaf fs.I#ist Index) 
End If 

If cboInterventionOutcome. Listlndex = -1 Then 

tmpstrl = d " 
Else 

tmpstrl » cboInterventionOutcome . I temData ( cboInterventionOutcome .List Index) 
End If 



If Trim ( txtEndDate ) = "" Then 

tmpDate = "12:00:00 PM" 
Else 

tmpDate = txtEndDate . Text 
End If 

cnn. Execute "Update Interventions Set StaffName = & tmpStr & * ' , EndDate = • " & tmpDate & . 
" • . InterventionOutcome *» * 0 & tmpstrl & ■ ■ , OutcomeNarrative « ■ ■ & _ 
txtOutcomeNarrative . Text & " 1 Where interventionSequence ■ " & SequenceNo 

tmpPosition = rstlnterventions.AbsolutePosition 

rstlnterventions . Requery 
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End If 
End If 
End If 
End With 
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rstlnterventions.AbsolutePosition = tmpPosition 
End Sub 

Private Sub CalculateScore 0 1 Calculate the Intervention Pre/ Post Scores 

If InterventionCode = ■ 013° Then ■ IL 

Calculate_IL_Score ' 
Elself InterventionCode = -014* Then ' Mobility 

Calculate_OMLScore 
Elself InterventionCode = "050° Then 1 Employment 

Calculate_EBL-Score 
Elself InterventionCode = B 010 a Then ' Social Service 

Calculate_SS_Score 
Elself InterventionCode « "160° Then • Computer Skills 

Calculate_CS_Score 
End If 

End Sub 

Private Sub Calculate_IIj_Score ( ) 

Dim TotalObjectives As Integer 
Dim Objectives As Integer 
Dim ObjAchieve As Long 
Dim AssessSeq As Integer 
Dim ProgressSeq As Integer 
Dim GoalSeq As Integer 
Dim Temp As Single 
Dim Functional As Single 
Dim Counter As Integer 

PreSelfScore =0 . 
Pre Provider Score =0 
AssessSeq = 0 
ProgressSeq = 0 

ObjAchieve =0 , 
Temp =0 

Counter =0 » 
TotalObjectives == 74 

• Calculate score only if there are visit records for the intervention 
Set rsScores = New ADODB . Recordset 

rsScores. CursorLocation = adUseClient* 

rsScores. Open "Select Duration Prom Visits Where ConsumerlD « n & CustomerlD & _ 

° And Agency = • n & AgencyCode & ■ 1 And CaseNumber = 1 « & CaseNumber & & , 

■ And Episode = ■ & Episode & ■ And interventionSequence « « & SequenceNo & _ 

■ And (Type » '5* or Type = 'lO')", cnn, adOpenForwardOnly , adLockReadOnly . 

With rsScores 

If Not (.BOF And . EOF) Then 
Temp = CInt ( ! [Duration] ) 

If Temp = 0 Then 1 0 minutes skip scoring 

Exit Sub 
End If 
Else 

Exit Sub * No visit records skip scoring 

End If I 
End With" 

rsScores. Close 

Set rsScores. = Nothing % 

• PreService Score 

Set rsScores = New ADODB. Recordset 

rsScores. CursorliOcat ion = adUseClient ^_ „ n r ~ 0 . 

rsScores. Open "Select TaskB, Assessment Sequence From iLAssessment Where ConsumerlD = & Lust 
ID & 

~" • - And Agency * f ■ & AgencyCode & n • And CaseNumber = ' 0 CaseNumber & ■ ' • & 

• And Episode = * & Episode & ■ And InterventionSequence « » & SequenceNo, _ 
cnn, adOpenForwardOnly, adLockReadOnly 
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With rsScores 

If Not (.BOF And .EOF) Then ■ Get the preprovider ratings for 

PreProviderScore « ! [taskB) 1 this intervention sequence 

AssessSeg = ! [AssessmentSequence] 

Else 

Exit Sub * No assessments for the consumer skip scoring 

End If 
End With 

rsScores .Close 

Set rsScores » Nothing 

PreServiceScore = PreProviderScore 

• PostService Score 

Set rsScores = New ADODB . Recordset 

rsScores. CursorLocation « adUseClient 

rsScores . Open "Select ProgressSeq From Progress Report Where ConsumerlD = n & Customer ID & _ 

" And Agency = ■ ° & AgencyCode & ° 1 And CaseNumber - ■ ° & CaseNumber & ■ ■ D & , 
t • And Episode = 0 & Episode & " And InterventionID = , 013 ,a & _ 

° And AssessmentSequence = " & AssessSeq, cnn, adOpenForwardOnly, adLockReadOr 

With rsScores 

If Not {.BOF And .EOF) Then 1 Get the Progress sequence for this intervention 

ProgressSeq = ! [ProgressSeq] 
Else 

Exit Sub 1 No progress report skip scoring 

End If 
End With 

rsScores '.Close 

Set rsScores = Nothing 

1 Get the GoalSeq for all goals 
Set rsScores = New ADODB. Recordset 
rsScores. CursorLocation = adUseClient 

rsScores. Open "Select GoalSeq From GoalAchieve Where ConsumerlD = ° & Customer ID & _ 

n And Agency = ' ■ & AgencyCode & n • And CaseNumber = ■ ° & CaseNumber & " • " & J 

" And Episode = ■ & Episode & " And InterventionID = 1 013 ■ ■ & _ 

q And ProgressSeq = " & ProgressSeq, cnn, adOpenForwardOnly, adLockReadOnly 

With rsScores 

If Not (.BOF And .EOF) Then 
While Not . EOF 

GoalSeq = ! [GoalSeq] 

* Get the achievement rating for all objectives 
Set rsScores2 = New ADODB . Recordset 
rsScores2 .CursorLocation = adUseClient 

rsScores2.0pen "Select Achievement From ObjectiveAchieve Where ConsumerlD » ° & Cust 

rID & _ 

" And Agency = • 0 & AgencyCode & w 1 And CaseNumber « ' ■ & CaseNumber fie 

" And Episode = ° & Episode & ■ And InterventionID = 1 013 • a & _ 

■ And GoalSeq = " & GoalSeq, cnn, adOpenForwardOnly, adLockReadOnly 

Objectives = Objectives +. rsScores2 -RecordCount 



With rsScores 2 

If Not (.BOF And .EOF) Then 
While Not .EOF 

Temp = ! [Achievement] 
Obj Achieve - Obj Achieve + Temp 
.MoveNext 
Wend 
* Else 

rsScbres2 . Close 

Set rsScores2 = Nothing 

rsScores .Close 

Set rsScores = Nothing 

Exit Sub ■ No achievements skip scoring" 

End If 
End With 
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.MoveNext 

Wend 
Else 

Exit Sub ' No goals 
End If 
End With 

rsScores2 .Close 

Set rsScores2 = Nothing 

rsScores . Close * 

Set rsScores =* Nothing 

Temp = TotalObjectives - Objectives 
If (Temp > 0) Then 

For Counter = 1 To Temp 

ObjAchieve = ObjAchieve + 10 1 Goals that were not rated are scored a 10 

Next 
End If 

PostServiceScore = ((ObjAchieve * 100) / 740) 
Temp = PostServiceScore - PreServiceScore 

Functional = Format$ ( ( (Temp / PreServiceScore) * 100), "Fixed") 

txtPreserviceScore.Text = PreServiceScore 
txtPostServiceScore.Text = PostServiceScore 
txtFunctionalChange.Text = Functional 

cnn. Execute "Update interventions Set PreServiceScore = " & PreServiceScore & _ 

0 , PostServiceScore = " & PostServiceScore &* " , FunctionalChange » n & Functional & _ 
• Where Consumer ID = ■ & Customer ID & _ 
" And Agency = * n & AgencyCode & ° ' And CaseNumber = • w & CaseNumber & ■ ' 0 & _ 
" And Episode - ■ & Episode " And InterventionSequence = & SequenceNo 



tmpPosition = rst Interventions .AbsolutePosition 
rstlnterventions.Reguery ■ 

rst Interventions. AbsolutePosition « tmpPosition 
End Sub 

Private Sub Calculate_OHJ3core( ) 

Dim TotalObjectives As Integer 
Dim Objectives As Integer 
Dim ObjAchieve As Long 
Dim AssessSeq As Integer 
Dim GoalSeq As Integer 
Dim ProgressSeq As Integer 
Dim Temp As Single 
Dim Functional As Single 
Dim Counter As Integer 

PreSelf Score = 0 
PreProvider Score = 0 
AssessSeq =0 
ProgressSeq = 0 
ObjAchieve = 0 
Temp = 0 
Counter = 0 
TotalObjectives = 44 

• Calculate score only if there are visit records for the intervention 
Set rsScores = New ADODB „ Recordset 
rsScores. CursorLocat ion = adUseClient 

rsScores. Open "Select Duration From Visits Where ConsumerlD = " & CustomerlD & _ 

« And Agency = •" & AgencyCode & ■ • And CaseNumber - ,n & CaseNumber & & 
■ And Episode = " & Episode & " And InterventionSequence = ■ & SequenceNo. & _ 
" " And (Type = *S % or Type - '10')", cnn, adOpenForwardOnly, adLockReadOnly 

With rsScores 



r 



•terventionl - 9 



If Not (.BOF And . EOF) Then 
Temp — CInt (.! [Duration] ) 
If Temp = 0 Then 

Exit Sub 
End If 
Else 

Exit Sub 
End If 
End With 



0 minutes skip scoring 



No visit records. skip scoring 



rsScores .Close 

Set rsScores = Nothing 



No assessments for the consumer skip scoring 



• PreService Score 
Set rsScores = New ADODB . Recordset 

jS^lSSr^i^wf^^tS*^ From MobilityAssessxaents Where Consumer!* = ■ . 

ustomerlD & _ AgencyCode & « • And CaseNumber - - ft CaseNu^er & ' ' " * _ 

- And Episode = • & Episode & - And InterventionSequence = & Sequenced. _ 
cnn, adOpenForwardOnly , adLbckReadOnly 

Wit 5/{2 t°TloF And EOF) Then ' Get the preprovider ratings for 

" PreProSLrstore = JJaskB] ■ this intervention sequence 

AssessSeq = ! [Assessment Sequence] 

Else 

Exit Sub 
End If 
End With 

rsScores . Close 

Set rsScores = Nothing 

PreServiceScore ■ PreProviderScore 

• PostService Score x 

Set rsScores « New ADODB. Recordset 

rsScores.CursorLocation = adUseClient WMRRmor . t where ConsumerlD - ■ & CustomerlD & _ 

rsScores.Open "Select -OgressSe* [r^^ere^ elfuntoer 

.I K SsessLntSe^^ — 
Wit ?£ r NotTBOF And .EOF) Then " ■ Get the Progress sequence for this intervention 

ProgressSeq = S [ProgressSeq] . 
ElS Exit Sub ' No Progress report skip scoring 

End If . 
End With 

rsScores .Close 

Set rsScores =• Nothing 

• Get the GoalSeq for all goals 
Set rsScores = New ADODB . Recordset 

■ a«rt Enisode = • & Episode & " And InterventionID = "0X3 & • . 

' • j£S ProgressSeq = • 6 ProgressSeq. cnn. adOpenForwardOnly, adLockReadOnly 



With rsScores 

If Not (.BOF And .EOF) Then . 
While Not .EOF 

GoalSeq = ! [GoalSeq] 

1 Get the achievement rating for all objectives 
Set rsScores2 * New ADODB . Recordset 
rsScores2.Cursor!iOcation » adUseClient 
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rsscores2.0pen -Select Achievement From Object iveAchieve Where ConsumerlD * - ft Custom 

rID & " -.And Agency - - ft AgencyCode ft And CaseNumber = ■ -ft CaseNumber ft — ft _ 

» And Etoisode = ° & Episode ft • And InterventxonID = '014 ft - 
• And GoalSeq - " & GoalSeq, cnn, adOpenForwardOnly, adLockReadOnly 

Objectives = rsScores .RecordCount 

With rsScores2 

If- Not (.BOF And -EOF) Then 
While Not -EOF _ 

Temp - ! [Achievement] 
ObjAchieve = ObjAchieve + Temp 
.MoveNext 
Wend 
Else 

rsScores2 . Close 

Set rsScores2 = Nothing 

rsScores .Close 

JS/X™ = NOthin9 • No achievements skip scoring 

End If 
End With 
Wend 
Else 

Exit Sub ' No goals 
End If 

End With 

rsScores . Close 

Set rsScores = Nothing * 

Temp = TotalObjectives - Objectives 
If (Temp > 0) Then 

W l t SSS^T' 1 C&SU + iO ' Goals that were not rated are scored a 10 

Next 
End If 

PostServiceScore = (ObjAchieve * 100) / 440 
Temp = PostServiceScore - PreServiceScore 

Functional = Format $ ( ( (Temp / PreServiceScore) * 100), "Fxxed ) 

txtPreserviceScore.Text - PreServiceScore 
txtPostServiceScore.Text = PostServiceScore 
txtFunctionalChange.Text = Functional 



a 'whe»x-e ConsumerlD = ■ & Customer ID ft _ 
- Md AgencT= " ft AgencyCode ft - And CaseNumber « - & CaseNumber ft 
• tod* Episode = • ft Episode ft ■ And interventionSequence - ' & SequenceNo 



ft _ 



tmpPosition = rs t Iiit erven t ions .Absolut ePos it ion 
rstlnterventions . Requery 

rstlnterventions.AbsolutePosition = tmpPosxtxon 
End Sub 

Private. Sub Calculate_EMLJ5core ( ) 
End Sub 

Private Sub Calculate_SS_Score < ) 
End Sub 

Private Sub Calculate_CS_Score < ) 



Dim TotalObjectives As Integer 
Dim Objectives As Integer 
Dim Ob j Achieve As Long 
Dim GoalSeq As Integer 
Dim AssessSeq As Integer 
Dim ProgressSeq As. Integer 
Dim Temp As Single 
Dim Functional As Single 
Dim Counter As Integer 

PreSelfScore =0 
PreProviderScore = 0 
AssessSeq = 0 
ProgressSeq = 0 
Ob j Achieve =0 
Temp = 0 
Counter =0 
TotalObjectives =7 

• calculate score only if there are visit records for the intervention 
Set rsScores = New ADODB . Recordset 

rsScores. Cursorbocation = adUseClient ronsumerlD = ■ & CustomerlD & _ 

"Sex- — - - 2»^S^^ C ^^"- 

With rsScores 

If Not (.BOF And .EOF) Then 
. Temp » CInt( ! [Duration] ) 

If Temp = O Then ' 0 minutes skip scoring 

Exit Sub ' 
End If 

El Exit Sub 1 No visit records skip scoring 

End If 

End With \. 

rsScores. Close 

Set rsScores = Nothing 

• PreService Score 

Set rsScores =» New ADODB . Recordset 

r |scorel:Sen°-Secc 0 ?as^f Ssless^tSequence Pro. Co^uterAssessment" Where ConsuxnerXD = - . 
stomerlD & _ a „ otlrv rnflp & And CaseNumber - ' 0 & CaseNumber ■«"•& _ 

: a sss.'- » * ssasf s^i-^ - - * _ 

cnn, adOpenForwardOnly, adLockReadOnly 

Wit Tf r N!t°f Iof And EOF) Then ' Get the preprovider ratings for 

" £eProv?aerst>re =' UtaskB! ■ this intervention sequence 

AssessSeq « i {AssessmentSequence] 

Else . _ w . No assessments for the consumer skip scoring 

Exit Sub 
End If 
End With 

rsScores .Close 

Set rsScores = Nothing 



PreServiceScore = PreProviderScore 

■ PostService Score 

Set rsScores « New ADODB . Recordset 

rsScores. CursorLocation = adUseClient where Consumer ID = ° & CustomerlD & _ 

rsScores. Open "Select ProgressSeq From ProgressReport Where consume 
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• And Agency = '* & AgencyCode *& ■ • And CaseNumber = ' ■ & CaseNumber 

■ And Episode = ■ & Episode & ° And InterventionlD = , 160 , ° & 

" And AssessmentSequence = ° & AssessSeq, cnn, adOpenForwardOnly, adLockReadOn. 

Wit If r Not O3 (?B0F And .EOF) Then • Get the Progress sequence for this intervention 

ProgressSeq = f [ProgressSeq] 

Else ... 
Exit Sub * No progress report skip scoring 

End If 
End With 

rsScores . Close 

Set rsScores = Nothing 

Set rsScores = New ADODB . Recordset 

rsScores. CursorLocation = adUseClient , . . ' _ „ - 

rsScores. Open ? Select Distinct GoallD, Achievement From GoalAchieve Where ConsumerlD & cus 

erID Sc _ ^ And Agency a . a & AgencyCode & ■ ' And CaseNumber = ■ ■ & CaseNumber & * 1 w & _ 

0 And Episode - 0 & Episode & " And InterventionlD = 'leO' 0 & 

■ And ProgressSeq = " & ProgressSeq, cnn, adOpenForwardOnly, adLockReadOnly 

Objectives = rsScores .RecordCount 

WXt If r Not°TTBOF And . EOF) Then ' Get the Achievement rating for each goal 

While Not .EOF 

Temp = ! [Achievement] 

Ob j Achieve .« Ob j Achieve + Temp 

.MoveNext 

Wend 
Else 

Exit Sub 1 No achievements skip scoring 

End If 

End With / 
rsScores. Close 

Set rsScores - Nothing ^ 

Temp = TotalObjectives - Objectives 
If (Temp > 0) Then 

For Counter = 1 To Temp 

ObjAchieve = Obj Achieve + 4 1 Goals that were not rated are scored a 4 

• Next 
End If 

PostServiceScore * ObjAchieve * 28 

Temp = PostServiceScore - PreServiceScore 

Functional = Format$ { ( (Temp / PreServiceScore) * 100), "Fixed") 

txtPreserviceScore.Text = PreServiceScore 
txtPostServiceScore.Text = PostServiceScore 
txtFunctionalChange.Text = Functional 

cnn. Execute "Update Interventions Set PreServiceScore = " & PreServiceScore & 

PostServiceScore = 0 & PostServiceScore & FunctionalChange = rt & Functional & _ 
- 'where ConsumerlD = " & CustomerlD & _ . . 

" And Agency = ■ ■ & AgencyCode & ■ 1 And CaseNumber = ' ° & CaseNumber & & - 
■ And Episode u ■ & Episode & 0 And InterventionSequence = ° & SequenceNo 

tmpPosition = rs tlntervent ions . Absolut ePosit ion 
rstlnterventions . Requery 

rstlnterventions.AbsolutePosition = tmpPosition 



End Sub. 



Private Sub cboStaf fName_JCeyUfc< KeyCode As Integer,. Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboStaf f Name . Lis tlndex = -1 

End If 
End Sub 

Private Sub cboGSuccessf ul_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboGSuccessful .Iiistlndex » -1 

End If 
End Sub 

Private Sub cboOSuccessful_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode ss vbKeyBack Then 

cboOSuccessful .List Index = -1 

End If 
End Sub 

Private Sub cmdClose_Click{) 

Unload Me 
End Sub 

Private Sub cmdNextObjective_Click() 

cmdPreviousObjective. Enabled "= True 
With rstObjectives 
.MoveNext 

If rstObjectives.RecordCount > 1 Then. 

If rstObjectives .AbsolutePosition = 1 Then 

cmdPreviousObjective. Enabled = False 

cmdNextObjective. Enabled = True 
Elself rstObjectives. AbsolutePosition < .RecordCount Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective. Enabled = True 
Elself rstObjectives.RecordCount = . AbsolutePosition Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective. Enabled » False 

End If 

Else 

cmdNextObjective. Enabled - False 
cmdPreviousObjective. Enabled « False 
End If 

LoadDataToControls rstObjectives, cboOSuccessful, False 
LoadDataToControls rstObjectives, txtOCompletionDate, False 
txtObjectives = rstObjectives ! [Description] 
txtCurrentObjective = rstObjectives .AbsolutePosition 
ObjectiveSeq = ! [ObjectiveSeq] 
End With 

End Sub ^ 

Private Sub cmdNExtRecord_Click( ) , 

With rstIRA 
. MoveNext 

txtTotalRecord = .RecordCount 
txtCurrentRecord = .AbsolutePosition 
ProgressReportSeq ! [ProgressSeq] 
If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord . Enabled = False 
cmdNextRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousRecord . Enabled *= True 
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Private GoalSeq As Long 
Private ObjectiveSeq As Long 
Private rstIRA As ADODB . Recordset 
Private rstGoal As ADODB . Recordset ; 
Private rstObjectives As ADODB. Recordset 



Private Sub cmdPreviousGoal_Click( ) 
With rstGoal 

. MovePreyious 

If .RecordCount > 1 Then \ 
If .AbsolutePosition = 1 Then 

cmdPreviousGoal. Enabled = False 

cmdNextGoal . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousGoal. Enabled = True 

cmdNextGoal. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousGoal . Enabled = True 

cmdNextGoal . Enabled = False < 

End If 

Else 

cmdNextGoal . Enabled = False 
cmdPreviousGoal .Enabled = False 
End If 

LoadDataToControls rstGoal, cboGSuccessful , False 

LoadDataToControls rstGoal, txtGCompletionDate , False s 
tx'tCurrentGoal = .AbsolutePosition 
txtGoal « rstGoal! (Description] 
GoalSeq = rstGoal ! [GoalSeq] 

If rstObjectives. State* = adStateOpen Then rstObjectives -Close 

rs tOb j ectives . Open " Select OA . GoalSeq, O . Description, OA . Achievement , OA . CompletionDate , OA . Ob 
iveSeq from n & _ 

"ObjectiveAchieve OA, pbjectives 0 where OA.GoallD = O.GoallD and OA.ObjectivelD « C 
ectivelD " & _ i 

°and OA. Episode « • & Episode & " And OA. InterventionID = 1 " & f rmlRAMenu . troplnterve 

nID & _ 

■ •* And- OA.ConsuraerlD = " & CustomerlD & ■ And OA. GoalSeq = n & GoalSeq, cnn, adOpenE 
ic, adLockOptimistic 

If Not rstObjectives. EOF Then 
rstObjectives .MoveFirst 
If rstObjectives. RecordCount > 1 Then 

cmdNextObjective. Enabled = True 
Else 

cmdNextObjective. Enabled =" False 
End If 

LoadDataToControls rstObjectives, cboOSuccessful, False 
LoadDataToControls rstObjectives, txtOCompletionDate, False 
txtObjectives = rstObjectives ! [Description] 
txtObjectiveCount - rstObjectives .RecordCount 
txtCurrentObjective = 1 

Set grdObj ectives. Da taSource = rstObjectives 
ObjectiveSeq = rstObjectives I [Object iveSeq] 
Else 

cmdNextObjective. Enabled =* False 

cmdPreviousObjective. Enabled = False 
End If 
End With 
End Sub 

Private Sub cmdNextGoal_Click ( ) 

With rstGoal- 
.MoveNext 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 
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cmdNextRecord . Enabled = True 
Elself -RecordCount = .AbsolutePosition Then 
cmdPreviousRecord. Enabled = True 
cmdNextRecord . Enabled = False 
End If 
End If 
End With 
End Sub 
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cmdPreviousGoal - Enabled = False 

cmdNextGoal. Enabled = True 
El self .AbsolutePosition < > RecordCount Then 

cmdPreviousGoal. Enabled * True 

cmdNextGoal. Enabled » True " 
Elself .RecordCount - .AbsolutePosition Then 

cmdPreviousGoal. Enabled = True 

cmdNextGoal . Enabled = False . 

End If 

Else 

cmdNextGoal. Enabled = False 
cmdPreviousGoal . Enabled = False 
End If 

LoadDataToControls rstGoal, cboGSuccessful, False 
LoadDataToControls rstGoal, txtGCompletionDate-, False 
txtCurrentGoal * .AbsolutePosition 
txtGoal ■ rstGoal! [Description] 
GoalSeq = rstGoal ! [GoalSeq] 

If rstObjectives. State = adStateOpen Then rstObjectives .Close 

rstObjectives.Open "Select OA. GoalSeq, 0. Description, OA. Achievement , OA. CompletionDate, 0A.O1 
tiveSeq from 0 & _ 

"ObjectiveAchieve OA, Objectives O where QA. Goal ID = O.GoallD arid OA.ObjectivelD = O 
ectivelD B & _ ' 

» and OA. Episode » 0 & Episode & " And OA.InterventionID = ' n & f rmlRAMenu . tmplnteryei 

nID & _ 

01 And OA. Consumer ID = ■ & CustomerlD & ° And OA. GoalSeq = 0 & rstGoal ! [GoalSeq] , cm 
dOpenDynamic , * adLockOp t imi s t i c 
If Not rstObjectives. EOF Then 
rs tObj ect ives . MoveFirst 
If rstObjectives. RecordCount > 1 Then 

cmdNextObjective. Enabled = True 
Else * 

cmdNextObjective. Enabled = False 
End If 

LoadDataToControls rstObjectives, cboOSuccessf ul. False 
LoadDataToControls rstpbjectives, txtOCompletionDate, False 
txtObjectives = rstObjectives ! [Description] 
txtObjectiveCount = rstObjectives .RecordCount 
txtCurrent Objective = rstObjectives .AbsolutePosition 
Set grdObjectives.DataSource = rstObjectives 
ObjectiveSeq = rstObjectives 1 t Object iveSeq] 
Else 

cmdNextObjective. Enabled = False 

cmdPreviousObjective. Enabled = False 
End If * 
End With 
End .Sub 

Private Sub cmdPreviousObjective_Click() 

cmdNextObjective. Enabled = True 
With rstObjectives 
. MovePrevious 

If rstObjectives. RecordCount > 1 Then 

If rstObjectives. AbsolutePosition ■ 1 Then 

cmdPreviousObjective. Enabled = False 

cmdNextObjective. Enabled = True 
Elself • rstObjectives. AbsolutePosition < .RecordCount Then 

cmdPreviousObjective -Enabled = True 

cmdNextObjective. Enabled = True 
Elself rstObjectives. RecordCount « .AbsolutePosition Then 
' cmdPreviousObjective .Enabled = True 

cmdNextObjective. Enabled = False 

End If 

Else 

cmdNextObjective. Enabled = False 
cmdPreviousObjective. Enabled ■ False 
End If 
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LoadDataToControls rstObjectives, cboOSuccessful , False 
LoadDataToControls rstObjectives, txtOCompletionDate, False 
txtObjectives = rstObjectives ! [Description] 
txtCurrentObjective = rstObjectives. AbsolutePosition 
ObjectiveSeq « 1 [ObjectiveSeq] 

End With 

End Sub 

Private Sub candPreviousRecord_Click( ) 

With rstIRA 

. MovePrevious 

txtTotalRecord = .RecordCount 
txtCurrentRecord = .AbsolutePosition 
ProgressReportSeq i (Pr ogres sSeq] 
If .RecordCount > 1 Then 

If . Absolut ePosit ion = 1 Then 

cmdPreviousRecord. Enabled = False 
cmdNext Record . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousRecord. Enabled = True 
cradNext Record. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 
cmdPreviousRecord. Enabled = True 
cmdNextRecord . Enabled = False 
End. If 
End If 
End With 
End Sub 

Private Sub cmdSave_jClick() 
Dim IngVar As Long 
Dim tmpDatel As String 
Dim tmpdate2 As String 
Dim tmpStr As String 
Dim tmpDate As String 
Dim tmpAchieve As String 

On Error GoTo errSave*. 

With rstIRA 

If cboStaf fs.Listlndex = -1 Then 

1 [Staff Name] = °° 
Else 

! [StaffName] » cboStaf fs. I temData {cboStaf fs .Lis tlndex) 
End If 

If Trim(txtProgressReport (0) ) = " ■ Then 

! [PeriodFrom] = "12:00:00 PM" 
Else 

! [ PeriodFrom] = Tr im ( txtProgressReport ( 0 ) ) 
End If 

If Trim( txtProgressReport (1) ) « ■ « Then 

![PeriodTo] = "12:00:00 PM" 
Else 

1 [PeriodTo] = Trim { txtProgressReport (1) ) 
End If 

'.[Summary] = Trim( txtProgressReport (2) ) 
.Update 
End With 

If cboGSuccessf ul . List Index = -1 Then 

tmpStr = aa 
Else 

tmpStr = cboGSuccessf ul . ItemData.(cboGSuccessf ul . List Index) 
End If 



If Trim(txtGCompletionDate) = on Then 

tmpDatel = ■ ■ • 

tmpDate = no 
Else 

tmpDatel = Trim(txtGCompletionDate) 
tmpDate = Trim(txtGCompletionDate) 
End If 

lnoVar = rstGoal.AbsolutePosition • *-«^ r 

• cnn; Execute -Update GoalAchieve Set Achievement = »■ & tmpStr & CompletxonDate = & tmpE 

1 & " 01 Where Episode = a & Episode &*° And InterventionlD = '° & f rmlRAMenu . tmplnterve 

onID & _ n 1 And consumerlD b ■ & CustomerlD & 0 And GoalSeq « ■ & GoalSeq 
rstGoal . Requery 

rstGoal.AbsolutePosition = IngVar 
grdGoals .Rebind 

If cboOSuccessful.Listlndex = -1 Then 
. tmpStr - ttD 
tmpAchieve = 0 0 
Else 

tmpStr « cboOSuccessful.ltemData(cboOSuccessful.Listindex) 
tmpAchieve = cboOSuccessful .Text 
End If 

If Trim(txtOCompletionDate) = 0 " Then 

tmpDatel = 0 D 

tmpDate = 0 " 
Else 

tmpDatel » Trim(txtOCompletionDate) 
tmpDate = Trim{txtOCompletionDate) 
End If 

IngVar = rstObjectives.AbsolutePosition ~ «. 1 o 

cnn. Execute "Update ObjectiveAchieve Set Achievement = & tmpStr & CompletionDate = 

pDatel & _ ^ mxere Episode = " & Episode & " And InterventionlD = »» & f rmlRAMenu . tmplnterv 

onID & _ ^ consumerlD » " & CustomerlD & " And ObjectiveSeg = 0 & ObjectiveSeq 

rstObjectives . Requery 

rstObjectives.AbsolutePosition = IngVar. 
grdOb j ect ives . Rebind 

MsgBox "Successfully saved the information ! " # vbOKOnly, 0 Save 0 
Exit Sub 

errSave : 

MsgBox Err. Description, vblnf ormation + vbOKOnly, ?Save° 
End Sub 

Private Sub Form_Load() 
Dim ProgressSeq As Long 

On Error G0T0 Errhandler 

LoadControl si terns cboStaffs, False 
txtConsumerName = FirstNaroe & 0 0 Be LastName 
txtEpisode = Episode 
txtCaseNumber » CaseNumber 

Set rstIRA = New ADODB . Recordset 
rstlRA.CursorLocation = adUseClierit 
. Set rstGoal ■ New ADODB . Recordset 
rstGoal .Cursor Location = adUseClient 
Set rstObj ect ives = New ADODB . Recordset 
r s tOb j ect ives. Cur sorLocat ion « adUseClient 

rstlRA.Qpen "Select Description From mterventionCodes Where Code » ■• & f rmlRAMenu . tmplnter 
onID J. 

& n, °, cnn, adOpenForwardOnly, adl^ockReadOnly 
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txtlntervention = rst IRA i [Description] 
rstIRA. Close 

rstIRA. Open -Select ProgressSeq, Staf f Name, Per iodFrom, Per iodTo, Summary from ProgressReport Wh 

^"Ssode & ° And Intervention^ « 10 & f rmlRAMenu. tmpInterventionID & • • And ConsumerlD = 

" Customer ID & ■ And CaseNumber = iB & CaseNumber & » • Order by ProgressSeq DESC°, cnn, adOpe 
namic, adLockOptimistic 
With rstIRA 

If Not (.EOF And -BOF) Then 

LoadDataToControls rstIRA, cboStaffs, False 
IioadDataToControls rstIRA, txtProgressReport , True 
ProgressReportSeq i [ProgressSeq] 
txtTotalRecord = .RecordCount 
txtCurrentRecord = .AbsolutePosition 

grdGoals. RowHeight =235 
grdObjectives.RowHeight = 235 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then. 

cmdPreviousRecord. Enabled = False 

cmdNextRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord. Enabled = True 

cmdNextRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNextRecord . Enabled « False 
End If 
End If 

End If * 
End With 
Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 

Private Sub Form__Unload (Cancel As Integer) 
rstIRA. Close 
rstGoal. Close 
. rstObjectives. Close 
Set rstIRA = Nothing 
Set rstGoal » Nothing 
Set rstObjectives = Nothing 
Set frmlRA = Nothing 
End Sub 



• Private Sub grdGoals_Click ( ) 

If grdGoals. SelBookmarks. Count = 0 Then Exit Sub 
rstGoal .AbsolutePosition = grdGoals . SelBookmarks ( 0 ) 

With rstGoal 

If Not .EOF Then 

If .RecordCount > X Then 

If .AbsolutePosition = 1 Then 

cmdPreviousGoal . Enabled = False 
cmdNextGoal. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousGoal . Enabled = True 
cmdNextGoal. Enabled = True 
Elself .RecordCount = * .AbsolutePosition Then 
cmdPreviousGoal . Enabled = True 
cmdNextGoal. Enabled ■ False 
End If 
End If 
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LoadDataToControls rstGoal, cboGSuccessful, False 
LoadDataToControls rstGoal, txtGCompletionDate, False 
txtCurrentGoal = - AbsolutePosition 
txtGoal * rstGoal ! [Description] 

GoalSeq = rstGoal! [GoalSeq] , . 

If rstObiectives.State = adStateOpen Then rstObDectives .Close «~i^ionnate OA < 

^Objectives. Open "Select OA. GoalSeq, 0. Description, OA. Achievement. OA. CompletxonDate. OA.< 

jeCtiVeS % D ;ectlveAchieve OA, Objectives O where OA.GoallD - O.GoallD and OA.ObjectivelD - 0.01 
ectivelD :£- 6A E&±sod& s . fc w>ode & . ^d OA . Intervention^ = & f rmlRAMenu . tmplntervent 

nID * " And OA.ConsumerlD * • * CustomerlD & « And OA.GoalSeq & rstGoal i [ GoalSeq] , cnn, 

dOpenDynamic , _ 

adliOckOptimistic 
With rstObjectives 
If Not . EOF Then 
.MoveFirst 

txtObjectives * ! [Description] 
txtObjectiveCount = . RecordCount 
txtCurrentObjective = .AbsolutePosition 

ObjectdveSeq = ! [Object iveSeq] ' . . . PaleA 

LoadDataToControls rstObjectives, cboOSuccessful, False 
LoadDataToControls rstObjectives, txtOCompletionDate, False 
Set grdObjectives.DataSource » rstObjectives 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousObjective. Enabled = False 

cmdNextObjective. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective. Enabled =» False 
End If 
Else 

cmdNextObjective. Enabled = False 
cmdPreviousObjective. Enabled = False 

End If 
Else 

cmdNextObjective. Enabled = False ■ . 

• cmdPreviousObjective. Enabled = False 

End If 
End With 
Else 

cmdPreviousGoal . Enabled = False 

cmdNextGoal. Enabled = False 
End If 
End With 
End Sub 

Private Sub grdObjectives_Click( ) 

If grdObjectives.SelBookmarks. Count = 0 Then Exit Sub 
rstObjectives. AbsolutePosition = grdObjectives . SelBookmarks (0) 

With rstObjectives 

If rstObjectives. RecordCount > 1 Then 
If .AbsolutePosition = 1 Then 

cmdPreviousObjective. Enabled = False 

cmdNextObjective. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousObjective. Enabled = True 

cmdNextObjective, Enabled » False 

End If 
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Else 

cmdNextObjective, Enabled = False 
cmdPreviousObjective. Enabled = False 

End If 

LoadDataToControls rstObjectives , cboOSuccessful, False 

LoadDataToControls rstObjectives, txtOCompletionDate, False 

txtobjectives = rstObjectives ! [Description] 

txtCurrentObjective « rstObjectives.AbsolutePosition 

Object iveSeq = ! [ObjectiveSeq] 
End With 
End Sub 

Private Sub txtGCompletionDate_Validate (Cancel As Boolean) 

If Trim( txtGCompletionDate) <> 00 Then 

If Not lsDate( Trim (txtGCompletionDate)) Then . . 

MsgBox "Please enter Date into this field!", vblnformation + vbOKOnly. "Goal Completior. 

e" 

txtGCompletionDate = nn 

txtGCompletionDate . SetFocus 

Cancel = True 
End If 
End If 
End Sub 

Private Sub txtOCompletionDate_Validate( Cancel As Boolean) 

If Trim ( txtOCompletionDate) <> Bn Then 

l£ Not IsDate (Trim( txtOCompletionDate) ) Then ■ 

MsgBox "Please enter Date into this field! ", vblnf ormatiOn + vbOKOnly. "ObDective Comp. 

n Date" 

txtOCompletionDate a °» 
txtOCompletionDate . SetFocus 
Cancel = True 
End If 

End If 1 
End Sub ' 

Private Sub txtProgressReport_Vali date (Index As Integer, Cancel As Boolean) 

If Tndex '= 0 Or Index = 1 Then 

If txtProgressReport (Index) <> "" Then 

If Not lsDate( txtProgressReport ( Index) ) Then 

MsgBox "Please enter Date into this field!", vblnformation + vbOKOnly, "Report Peri 
txtProgressReport (Index) » 0 
txtProgressReport (Index) .SetFocus 
Cancel = True 
End If 
End If 

End If , 
End Sub 

Private Sub ProgressReportSeg(SequenceNo As Long) 

If rstGoal. State « adStateOpen Then rstGoal .Close , 

rstGoal. Open "Select GA . GoalSeq , G . Description , GA . Achievement , GA . Complet ionDate from GoaiAcna 
A " & 

7 Goals G Where GA. Goal ID = G.GoallD and GA. Episode = " & Episode & " And GA.Intervent 
= 1 ■ u 

frmlRAMenu.tmpInterventionID & ■ ' And GA.ConsumerlD = " & Customer ID & " And GA.Progre 
= " & _ 

SequenceNo, cnn, adOpenEynamic, adLockOptimistic 
If Not rstGoal. EOF Then 

If rstGoal. RecordCount > 1 Then cmdNextGoal .Enabled = True 
cmdSave . Enabled = True 

LoadDataToControls rstGoal, cboGSuccessful, False 
liOadDataToControls rstGoal, txtGCompletionDate, False 
GoalSeq * rstGoal ! [GoalSeq] 
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txtGoalCount = rstGoal . RecordCount 

txtCurrentGoal = 1 

txtGoal - rstGoal J [Description] 

Set grdGoals.DataSource = rstGoal , 

If rstObiectivea. State = adStateOpen Then rstObnectives .Close 

rstObjeqtives.Open -Select OA.GoalSeq, 0. Description, OA. Achievement, OA. CompletionDate , OA.Ot 

tiVeSe ?ObStivSAchieve OA, Objectives 0 where OA.GoallD = O.GoallD and OA. Objective^ = O.Ob: 

iVeI ° «and"0A.Episode = ■ & Episode & ■ And OA . InterventionlD = »■ & f rmlRAMenu . tmplnterventic 

& - »• And OA . Consumer ID o - & CustomerlD & - And OA.GoalSeq * ■ &. GoalSeq, cnn, adOpenDynai 
adLockOptimistic 

If Not rstObjectives.EOF Then 

If rstObjectives. RecordCount > 1 Then 

cmdNextObjective. Enabled = True 
Else 

cmdNextObjective. Enabled = False 
End If 

LoadDataToControls rstObjectives, cboOSuccessful, False 
LoadDataToControls rstObjectives, txtOCompletionDate, False 
ObjectiveSeq = rstObjectives ![ Object iveSeql 
txtObjectives = rstObjectives 1 [Description] 
txtObjectiveCount = rstObjectives. RecordCount 
txtCurrentObjective - 1 . 

Set grdObjectives.DataSource = rstObjectives' 
End If 
End If 
End Sub 
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Public tmpInterventionID As String 

Private Sub cmdciose_Click() 

Unload Me 
End Sub 

Private Sub cmdComputerSkills_Click{) 

tmpInterventionID = "160° 

frmlRA.Show vbModal 
End Sub 

Private Sub cmdEmployment_Click ( ) 

.txnpInterventionID = "050" 

frmlRA.Show vbModal 
End Sub » 

Private Sub cmdIndependentLiving_Click() 

tmpInterventionID = "013" 

frmlRA.Show vbModal 
End Sub 

Private Sub cmdMobilityAssessment_Click ( ) 

tmpInterventionID = "014" 

frmlRA.Show vbModal 
End Sub 

Private Sub cmdSoci al Worked ick ( ) 

tmpInterventionID = "010" 

frmlRA.Show vbModal 
End Sub 

Private Sub PornuLoadO 

Dim rst As New ADODB. Recordset 

rst ^ Open "Select ConsumerlD From ProgressReport Where Consumer ID= " & CustomerlD & " And Epis« 
& _ 

Episode & " And Interventions = '014'", cnn, adOpenForwardOnly, adLockReadOnly 
cmdMobilityAssessment. Enabled » Ilf (rst. EOF, False, True) 
rst;. Close * 

rst. Open "Select ConsumerlD From ProgressReport Where ConsumerID= n & CustomerlD & ■ And Epis. 

Episode & " And Interventions = • 013 • " , cnn, adOpenForwardOnly, adLockReadOnly 
cmdlndependentLiving. Enabled « Ilf (rst. EOF, False, True) 
rst. Close 

rst. Open "Select ConsumerlD From ProgressReport Where ConsumerID=" & CustomerlD & ■ And Epis 

Episode & " And Interventions = , 160 ,w , cnn, adOpenForwardOnly, adLockReadOnly 
cmdComputerSkills. Enabled = Ilf (rst. EOF, False, True) 
rst. Close 

rst. Open "Select ConsumerlD From ProgressReport Where Consumer JD=" & CustomerlD & " And Epis 
St _ 

Episode & 0 And Interventions = '050'", cnn, adOpenForwardOnly, adLockReadOnly 
cmdEmployment. Enabled » Ilf (rst. EOF, False, True) 
rst. Close 

rst. Open "Select Consumers From ProgressReport Where ConsumerID=" & CustomerlD & " And Epis 
& _ 

Episode & " And Interventions = '010'", cnn, adOpenForwardOnly, adLockReadOnly 
cmdSocialWork. Enabled = Ilf (rst. EOF, False, True) 
rst. Close ' 

i 

Set rst = Nothing 
End Sub 
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Option Explicit 

Private ratMain As ADODB. Recordset 
Private rst As New ADODB - Recordset 

Private Sub cboEpisode_Click{ ) 

If cboEpisode.Listlndex .<> -1 Then 
Episode = Trim(cboEpisode.Text) 
If rst. State = adStateOpen Then rst. Close 

rst. Open "Seiect Episode, EpisodeCloseDate From Triage Where ConsumerlD = D & CustomerlD l 
nd Agency = ' ° & _ 

AgencyCode & 01 And CaseNumber = ,D & * CaseNumber & 01 And Episode = ■ & cboEpisoc 

xt, cnn, _ * 

adOpenForwardOnly , adLockReadOnly 
If rst! [EpisodeCloseDate] = "12:00:00 PM° Then 

txtEpisodeCloseDate = au 
Else 

txtEpisodeCloseDate » rst ! [EpisodeCloseDate] 
End If 

Call DisplayMainMenu 
End If * ' 

End Sub 

Private Sub cmdAssessments_Click() 

f rmAssessments . Show vbModal 
End Sub 

Private Sub- cmdClose^ClickO 

Unload Me 
End Sub 

Private Sub cmdEyeData_Click { ) 

frmEyeData . Show vbModal 
End Sub 

Private Sub cmdln t erven tions_Click( ) 

f rmlnterventionl . Show vbModal 
End Sub j 

Private Sub cmdlRA^ClickC ) 
f rmlRAMenu . Show vbModal 
End Sub 

Private Sub CmdPayer_Click( ) 

f rmPayer . Show vbModal 
End Sub 

Private Sub cmdRegistration_Click ( ) 

frmRegistrationl .Show vbModal 
End Sub 

Private Sub cmdReport_Click() 
f rmReportMenu.Show vbModal 
End Sub 

Private Sub cmdSearchMenu_Click( ) 
cboEpisode. Clear 
Episode =0 

cmdlntervent ions . Enabled = False 
cmdAssessments .Enabled = False 
f rroSearchMenu .Show 
End Sub 

Private Sub cmdTriage_Click<) 

f rmTriage . Show vbModal 
End Sub 

Private Sub FbrttuActivate ( ) 
txtLastName = LastName 
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txtFirstName = FirstName 
txtCaseNumber « CaseNumber 

cboEpisode . Clear 

If rst. State = adStateOpen Then rst. Close 

rst. Open "Select Episode, EpisodeCloseDate From Triage Where ConsumerlD = " & CustomerlD & ° A 
Agency - 9 " & _ • 

AgencyCode & D 1 And CaseNumber = ' n & CaseNumber & ° * Order by TriageSqe DESC" , cn 
adOpenForwardOnly , adLockReadOnly 
With rst 

If Not ( .BOF And .EOF) Then 

If ("[EpisodeCloseDate] = "12:00:00 PM" Or IsNull (! [EpisodeCloseDate] > > Then 

txtEpisodeCloseDate = 
Else 

txtEpisodeCloseDate = 1 [EpisodeCloseDate) 
End If 1 

While Not .EOF 

cboEpisode. Addltem ! [Episode] 

. MoveNext 
Wend 

cboEpisode. Lis tlndex =0 
End If 
End With 



If IsNumeric (cboEpisode. Text) Then- 

Episode = CLng (Trim (cboEpisode. Text ) ) 

Call DisplayMainMenu 
End If 

txt AgencyCode . SetFocus 
End Sub 

Private Sub FormJkoadO 

On Error GoTo Errhandler 

txtLastName * LastName 
txtFirstName = FirstName 
txtCaseNumber = CaseNumber 

Set rstMain = New AD0DB. Recordset 
rs tMain . Cur sorLocat ion = adUseClient 

Set rst = New AD0DB. Recordset 
rst .Cursorliocation = adUseClient 

Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 

Private Sub cmdEndOf Episode_Click( ) 
frmEndOf Episode. Show vbModal 
End Sub 

Private Sub *cmdPostEpisode — Click ( ) 

frmPostEpisodel.Show vbModal - * 

End Sub 

Private Sub DisplayMainMenu ( ) 

If rstMain. State = adStateOpen Then rstMain. Close 
If rst. State = adStateOpen Then rst. Close 

rstMain. Open "Select Mobil ityTherapy, IndependentLiving, LowVision, Insulin, DiabetesManagemen 
ychotheraj)y r * & _ 

"AcademicSkills,ComputerSkills, Employment, SocialService, ReadingService, MusicS 
1 , CDC From. Triage Where ConsumerlD = " & _ 
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Customer ID & " And Agency = ■ ° & AgencyCode & B 1 And Episode = ° & Episode & ° And 
seNumber = » " & ^ 

CaseNumber & °' cnn, adOpenForwardOnly, adl»ockReadOnly 

With rstMain 
If . EOF Then 

cmdEndOf Episode. Enabled = False 
cmdPostEpisode. Enabled = False 

If (! Mobil ityTherapy = °l n Or » IndependentLiving « n l n Or ! Employment « "1° Or ! Computer 
lis = n l° Or _ 

•Social Service = "1") Then 
cmdAs sessments. Enabled = True 
Else 

cmdAssessments. Enabled = False 
End If 

If (J Mobil ityTherapy = n l" Or ! IndependentLiving = °1" Or ".Employment = a l° Or IComputer 

ils = B l° Or _ _ _ 

ISocialService = "l" Or i&owVision = "l" Or ! DiabetesManagement = "1" Or !Psycbott 

py = "1° Or _ 

IAcademicSIcills = °1" Or llnsulin = «i» Or !ReadingService - °1° Or IMusicSchool = 
0 Or !CDC = °1") Then 

cmdlnfceryentions . Enabled = True 
CmdPayerl Enabled = True 
Else 

cmdln t erven t ions- Enabled = False 
CmdPayer. Enabled = False 
End If 

rst. Open "Select ConsumerlD From ProgressReport Where Consumer ID= " & Customer ID & " And 
sode = ° & Episode & _ 

" And CaseNumber = ■ M & CaseNumber & ° ,tt , cnn, adOpenForwardOnly, adliOckReadOnly 
If rst.EOF And rst.BOF Then 

cmdIRA . Enabled = False 
Else 

cmdIRA. Enabled = True 
End If , 
rst. Close . 1 

'rst. Open "Select ConsumerlD from Triage Where {isdate (EpisodeCloseDate) And EpisodeClos* 
e <> #12:00:00 PM#> And ConsumerlDs 0 & 

CustomerlD & n And Episode * n & Episode & ■ And CaseNumber - 1 » & CaseNumber & ****** 
, adOpenForwardOnly, adLockReadOnly 
If rst.EOF And rst.BOF Then 

cmdEndOf Episode . Enabled = False 
Else 

cmdEndOf Episode. Enabled = True 
End If 
rst. Close 

rst. Open "Select ConsumerlD from QA Where ConsumerID=" & CustomerlD & " And Episode = ° 
pisode & _ _ 
0 And CaseNumber = • n & CaseNumber &. " ' " , cnn, adOpenForwardOnly, adLockReadOnly 
If rst.EOF And rst.BOF Then 

cmdPostEpisode. Enabled = False 
Else 

cmdPostEpisode. Enabled = True 
End If 
rst. Close 
En<? If 
End With 
End Sub 

Private Sub Forn\_Unload (Cancel .As Integer) , 
If Forms. Count = 1 Then 

If cnn. State = adStateOpen Then cnn. Close 

Set cnn = Nothing 
End If 
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If rst. State = adStateOpen Then rst. Close 
Set rst = Nothing 

If rstMain. State = adStateOpen Then rstMain. Close 
Set rstMain « Nothing 
Set f rmMainMenu ' = Nothing 
End Sub 
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Option Explicit 

Private IsArrowKey As Integer 

Private rst As ADODB . Recordset 'resordset object variable 

Private rstMobility As ADODB . Recordset 

Private IsVisuallnf oClicked As Boolean 

Public IsNewRecord As Boolean 

Private IsGoalsClicked As Boolean 

Public IsFileDateChecked As Boolean 

Private Sub cboAgencyServices^KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

i 

If KeyCode = vbKeyBack Then 

cboAgencyServices (Index) .Lis tlndex = -1 . 
End If ' 
End Sub 

Private Sub cboAgree__KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboAgr ee ( Index ) . I*i s t Index = - 1 
End If 

End Sub N 
Private Sub cboAgree_JjostFocus (Index As Integer) 

If CheckForTab Then 
If Index = 38 Then 

tabMobility.Tab = 2 
El self Index =28 Then 

tabMobility.Tab = 3 
El self Index =20 Then 

tabMobility.Tab = 4 * 
Elself Index = 15 Then 

tabMobility.Tab = 5 
Elself Index = 6 Then 

tabMobility.Tab = 6 
Elself Index = 0 Then 

tabMobility.Tab = 7 . - 
End If 
End If 
End Sub 

Private Sub cboAgree_Validate( Index As Integer, Cancel As Boolean) 

If Index = 0 Or Index = 1 Or Index = 2 Or Index = 3 Or Index = ,4 Or Index = 5 Then 

If cboYesNo (18) .List Index <> 0 Then cboAgree (Index) .Lis tlndex = -1 
Elself Index = 6 Or Index = 7 Or Index = 8 Then 

If cboYesNo{19) .Listlndex <> 0 Then cboAgree (Index) .liistlndex = -1 
Elself Index = 9 Or Index =10 Or Index = 11 Or Index = 12 Or Index = 13 Or Index = 14 Or Indc 
15 Or Index = 16 Then 

If cboYesNo(20) .Listlndex <> 0 Then cboAgree (Index) -Listlndex = -1 
Elself Index = 17 Then 

If cboYesNo (21) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 18 Or Index = 19 Then 

If cboYesNo (22) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 20 Or Index = 21 Or Index = 22 Or Index = 23 Or Index = 24 Or Index = 25 Then 

If cboYesNo (23) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index =26 Then 

If cboYesNo(24) .Listlndex <> 0 Then cboAgree ( index) .Listlndex = -1 
Elself Index = 27 Or Index = 28 Or Index = 29 Or Index = 30 Or Index = 31 Or Index = 32 Or In« 
= 33 Or Index = 34 Then 

If cboYesNo (25) .Listlndex <> 0 Then cboAgree (Index) -Listlndex = -1 
Elself Index =35 Then 

If cboYesNo (2 6) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 42 Or Index = 43 Then 

If cboYesNo (27) .Listlndex <> 0 Then cboAgree (Index) .Listlndex = -1 
Elself Index = 36 Or Index = 37 Or Index = 38 Or Index = 39 Or Index = 40 Or Index = 41 Then 

If cboYesNo (28) .Listlndex <> 0 Then cboAgree (Index) .X*is tlndex = -1 
End If 
End Sub 
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Private Sub cboConsumerRating_KeyUp< Index As Integer, KeyCode As Integer, Shift As Integer) 



If KeyCode = vbKeyBack Then 

cboConsumerRating ( Index) .Listlndex = -1 

End If 
.End Sub 

Private Sub cboDif f iculty_KeyUp( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboDif ficulty( Index) .Listlndex « -1 
End If 
End Sub 

Private Sub cboEg^iipinent JKeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboEquipment (Index) .Listlndex = -1 
End If 
End Sub 

. Private Sub cboExternalServices_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboExternalServices (Index) .Listlndex = -1. 
End If 
End Sub 

Private Sub cboFactors_Click ( Index As Integer) 
If IsArrowKey > 0 Then Exit Sub 

If Index = 4 Then 

CountScore 

CountGoals 
End If \ 
End Sub 



Private 



Sub cboFactors_KeyDown( Index As Integer, KeyCode As Integer, Shift As Integer) 



If KeyCode = vbKeyUp Then' 

IsArrowKey = KeyCode • 
El self KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
El self KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboFac tor s_Lost Focus (Index As Integer) 

If CheckForTab Then 
If Index = 4 Then 
CountScore 
CountGoals 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 



Private Sub cboQbserveResponse_KeyUp (Index As Integer, KeyCode As Integer,' Shift As Integer) 



If KeyCode = vbKeyBack Then 

cboObserveResponse ( Index) .Listlndex = -1 
End If 
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End Sub 

Private Sub cboRating_KeyUi>( Index As Integer, KeyCode As Integer. Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRating( Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cbbServiceLevel_Click( Index As Integer) 
If IsArrowKey > 0 Then Exit Sub 

" S d cboSe^ - - 1 <* cboServiceLevel(Index).I.istIndex = 0 Then 

txtAssessment (14) = ° M 

E1S cboTimeFrame.ListIndex = cboServiceLevel (Index) .List Index - 1 

txtAssessment (14) = cboTimeFrame . Text 

Call CountGoals 
End If 

tabMobility.Tab = 9 
End If - 

End Sub 

Private Sub cboServiceLevel_KeyDown( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode =* vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub • 

Private Sub cboServiceLevel_JiOSt Focus (Index As Integer) 
If Index = 0 Then 

" S?c£l£5ce£vel (index, .Ustlndex = -1 Or cboServiceLevel (Index, .Mstlndex = 0 Then 
txtAssessment (14) = ■ " 
Else 

cboTimeFrame. Lis tlndex = cboServiceLevel (Index) .List Index - 1 
txtAssessment (14) = cboTimeFrame . Text 
Call CountGoals 
End If 

tabMobility.Tab = 9 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey =0 
End Sub 



Private Sub cboStaf fs_KeyUp( KeyCode As Integer, Shift As Integer) 



If KeyCode = vbKeyBack Then 
cboStaf fs. Listlndex = -1 
End If 
End Sub 



Private Sub cboYesNo_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 



If KeyCode = vbKeyBack Then 

cboYesNo( Index) .Listlndex = -1 
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End If 
End Sub 

Private Sub cboYesNo^LostFocus (Index As Integer) ^ ^ 

If Index * 17 Or Index = 16 Or Index = 15 Or Index = 14 Or Index - 13 Or Index = 12 Or Index * 
Or _ 

Index = 10 Or Index = 9 Or Index = 8 Then 
If CheckForTab Then 

If cboYesNo (Index) .Listlndex = 0 Then 

cboObserveResponse ( Index - 8) .Set Focus 

Else 

If Index = 8 Then 

* txtAssessment (5) .SetFocus 
Else 

cboYesNo( Index - 1) .SetFocus 
End If 
End If 
End If 

End If • 
End Sub 

Private Sub cmdClear_Click() 

IsArrowKey = 20 'Avoid Conbo Click event 

IsNewRecord =* True i 

clearData txtAssessment, True 

clearData IstDestinations tm False 

clearData chkGoals, True 

clearData cboYesNo, True 

clearData cboAgree, True 

clearData cboExternalServices , True 

clearData cboAgencyServices , True 

clearData cboE<juipment , • True 

clearData cboServiceLevel , True 

clearData cboFactors, True 

clearData cboStrategiesLearning, False . , 

clearData cboObserveResponse/ True 

clearData cboConsumerRating,. True 

clearData cboRating, True * 

clearData cboDif f iculty. True 

clearData cboStaf fs. False 

If Not rstMobility.BOF Then rstMobility .MoveFirst 

txtCurrentRecord = 0 " 

cmdPr int. Enabled = False 

cmdSave. Enabled = True 

tabMobility.Tab =0 

IsArrowKey. = 0 

End Sub 



Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdHistorical_Click( ) 
IsVisuallnfoClicked = True 
frmEyeData.Show vbModal 

End Sub 



Private Sub cmdNext_Click{ ) 
If tabMobility.Tab « 9 Then 

; MsgBox "It is last page for Services Agreement already I tt , vbOKOnly, "Next Page 

Else 

tabMobility.Tab = tabMobility.Tab + 1 
frmMobility. Caption = getTabCapt ion (tabMobility.Tab) 
End If 
End Sub 



Private Sub cmdNExtRecordLClickt) 



With rstMobility _ 
.MoveNext 

If .AbsolutePosition = X Then 

cmdPreviousRecord. Enabled - False 

cmdNExtRecord. Enabled « True 
Elself .AbsolutePosition < .RecordCount •Then 

cmdPreviousRecord . Enabled = True 

cmdNExtRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNExtRecord. Enabled = False 
End If 

txtCurrentRecord = .AbsolutePosition 
txtSequencyNo = ! [AssessmentSequence] 

LoadDataToControls rstMobility, IstDestinations, False 
LoadDataToControls rstMobility, cboStrategiesliearning, False 
LoadDataToControls rstMobility, cboStaffs, False. 
LoadDataToControls rstMobility, txtAssessment, True 
LoadDataToControls rstMobility, chkGoals, True 
IiOadDataToControls rstMobility, cboYesNo, True 
LoadDataToControls rstMobility, cboAgree, True 
LoadDataToControls rstMobility, cboExternal Services, True 
LoadDataToControls rstMobility, cboAgencyServices , True 
LoadDataToControls rstMobility, cboEquipment , True 
LoadDataToControls rstMobility, cboServiceLevel , True 
LoadDataToControls rstMobility, • cboObserveResponse , True 
LoadDataToControls rstMobility, cboConsumer Rating, True 
LoadDataToControls rstMobility, cboRatin£, True 
LoadDataToControls rstMobility, cboDif f iculty. True 
LoadDataToControls rstMobility, cboFactors, True 

If ! [FinishDate] = ■ 12: 00: 00 PM n Then 

cmdSave . Enabled = True v 

cmdPrint . Enabled = False 

cmdClear. Enabled = False 
Else 

cmdSave . Enabled = False 
cmdPrint * Enabled = True 
cmdClear. Enabled = True 
End If 
End With 

tabMobility.Tab = 0 
txtCurrentRecord . SetFocus 
End Sub 

Private Sub cmdPrevious_Click{ ) 
If tabMobility.Tab = 0 Then 

MsgBox °It is first page for Self Assessment already!", vbOKOnly, "Previouse Page" 
Else 

tabMobility.Tab » tabMobility.Tab - 1 

frmMobility. Caption = getTabCapt ion (tabMobility.Tab) 
End If 
End Sub 

Private Sub cnndPreviousRecordLciickC ) 

With rstMobility 
. MovePrevious 

If .AbsolutePosition = 1 Then. 

cmdPreviousRecord. Enabled = False 

cmdNExtRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord. Enabled * True 

cmdNExtRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNExtRecord. Enabled = False 
End If 
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If ! [FinishDate] = "12:00:00 PM° Then 

cmdSave. Enabled. = True 

cmdPrint . Enabled = False 

cmdclear .Enabled » False 
Else 

cmdSave . Enabled = False 
cmdPrint .Enabled = True 
cmdclear. Enabled = True 
End If 

txtCurrentRecord = . AbsolutePosition 
txtSequencyNo = 1 [Assessment Sequence] 

LoadDataToControls rstMobility, IstDestinations, False 
LoadDataToControls rstMobility, cboStrategiesLearning, False 
LoadDataToControls rstMobility, cbbstaffs. False 
LoadDataToControls rstMobility, txtAssessment, True 
LoadDataToControls rstMobility, chkGoals, True 
LoadDataToControls rstMobility, cboYesNo , True 
LoadDataToControls rstMobility, cboAgree, True 
LoadDataToControls rstMobility, cboExternalServices , True 
LoadDataToControls rstMobility, cboAgencyServices , True 
LoadDataToControls rstMobility, cboEquipment , True 
LoadDataToControls rstMobility, cboServiceLevel , True 
LoadDataToControls rstMobility, cboObserveResponse, True 
LoadDataToControls rstMobility, cboConsumer Rating, True 
LoadDataToControls rstMobility, cboDif f iculty, True 
LoadDataToControls rstMobility, cboRating, True 
LoadDataToControls rstMobility, cboFactors, True 
End With 

tabMobility:Tab =0 
txtCurrentRecord . SetFocus 
End Sub 

Private Sub cmdPrint_Click ( ) 
Dim i As Integer 

" MlgBox r -No°^inter Sund associating with this, computer. Please add a printer to it and the, 
ou can print, out the Service agreement! " , _ 
vbOKOnly, "Printer" 

Else 

. ^S^Selecf 2 t £K5b2ES£S Where Assessn.entSesuence^ - * txtSequencyNo. cnn 
dOpenkeyset^a^ckOpt^isti^ ^ ^ ^ . fc ^ create . new report 

rst. Delete 
End If 
rst .Close 

If rst. State = adStateOpen Then rst. Close ■ • ^commnrvWn cnn 

rst. Open "Select * from Mobil ityAgreement Where Assessment Sequence = & txtSequencyNo, cnn 
dOpenKeyset, adLockOptimistic 
With rst 
♦ If .BOF And . EOF Then 
. AddNew 

! [CaseNumber) = txtCaseNumber 

i [Episode] = txtEpisode 

! [Assessment Sequence] « txtSequencyNo 

! [ConsumerName] = txtConsumerName 

! [AssessmentDate] = txtAssessment (0) 

! [AssessorName] = cboStaf f s .Text 

For i a 0 To chkGoals. Count - 1 

If chkGoals (i) -Value = 0 Then 
.Fields (chkGoals (i) -Tag) = 

Else ""' 
. Fields < chkGoals (i) .Tag) "Yes" 

End If 
Next • 
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For i = 0 To 7 « 

. Fields ( cboYesNo C i ) . Tag) = cboYesNo ( i ) . Text 
Next 

For i « 0 To cboEquipment. Count - 1 

.Fields (cboEquiprtient(i) .Tag) » cboEquipment (i) . Text 
Next 

For i = 0 To cboAgencyServices. Count - 1 

.Fields (cboAgencyServices(i) .Tag) ■ cboAgencyServices <i) .Text 
Next 

For i = 0 To cboExterhalServices. Count - 1 

.Fields (cboExternalServices(i) .Tag) = cboExternalServices ( i ) . Text 

Next 

■ . Fields ( " TimeFrame u ) = cboTimeFrame . Text 
.Fields {"Comments") « txtAssessment (8) .Text 
.Update 
End If 
End With 

Set MobilityAgreement.DataSource = rst 

MobilityAgreement . PrintReport 
End If 
End Sub 

Private Sub cmd$ave — Click < ) 
Dim i As Integer 

Dim colMobility As New Collection 

On Error GoTo errSave 

colMobility. Add cboRating 
colMobility. Add cboAgree 
colMobility. Add IstDestinations 
colMobility. Add cboStrategiesLearning- 
colMobility. Add cboStaffs 
colMobility .Add txtAssessmen^ 
colMobility. Add chkGoals 
colMobility. Add cboYesNo 
colMobility. Add cboExternalServices 
colMobility. Add cboAgencyServices 
colMobility. Add cboEquipment 
colMobility. Add cboServiceLevel 
colMobility. Add cboFactors 
colMobility. Add cboObserveResponse 
colMobility. Add cboConsumerRating 
colMobility. Add cboDif f iculty 

If IsDate (txtAssessment (0)) Then • if filing assessment make sure learning sti 

ies 

If cboStrategiesLearning.Listlndex -1 Then ■ and factors are there 
tabMobility.Tab' = 8 

cboStrategiesLearning . SetFocus . . . „ tr ^nniv uo*-^ 

MsgBox "You have to select one of items from Strategies for Learning!", vbOKOnly, strc 

Learning" 

Exit Sub 
End If 

For i = O'To cboFactors. Count - 1 

If cboFactors (i) .Listlndex a -1 Then 
tabMobility.Tab =8 

MsgBrc^ one of items from Factors!", vbOKOnly, "Factors" 

Exit Sub 
End If 
Next 
End If 

If SaveDataToDB(frmMobility, rstMobility, colMobility, "014", False) Then 'Call pub: 
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^MtgBox 0 - Success fully saved the Assessment information! 0 , vbOKOnly, "Save" 

" c^S^-^^ntirvlntions Set PreConsumerScore = - & txtConsumerScore * Pre 
viderSC ° r txtProviderScore & • • Where ConsumerlD = - & CustomerlD & - And Agency - • ■ * AgeneyC 



t _ 



»■ And Episode =' " & Episode & " And CaseNumber = & CaseNumber & - 

And InterventionID = -014- And (EndDate = #12:00:00 PM# or EndDate IS^ 
cnn. Execute -UPDATE MobilityAssessments AS a INNER JOIN interventions AS b ON (a.caseNuir 

= b. CaseNumber)- m b Episode) ^ (a . C onsumerID = b.ConsumeriD) SET a . InterventionSeq 

ce = = 1Q14 . ^ b . CaseNum be r . - * CaseNumber & " 1 AND (b.EndDe 

= #12:00:O0PM# OR b. EndDate IS NULL) " & _ 
■ AND a.InterventionSequence = 0° 

End If. 

frmMobility. Refresh 
If IsNewRecord Then 

r s tMobi li ty . Reguery . i 

txtSequencyNo rstMobility! [Assessment Sequence] ^ 
End If 

f rmMobi 1 i ty . Refresh 

IsNewRecord * False 

Set colMobility = Nothing 
End If 
Exit Sub 

err Save * 

MsgBox Err. Description & Err -Number. vbCritical + vbOKOnly, "Save" 
End Sub 

Private Sub FomtJVctivate ( ) 
On Error GoTo Errhandler 

If IsVisuallnfoClicked Then 

IsVisuallnfoClicked = False 

Exit Sub 
End If 

txtConsumerName = FirstName & " ■ & LastName 
txtPhone = PhoneNo 
txtAddress = Address 
txtCaseNurnber = CaseNumber 
txtEpisode = Episode 

txt Intervention « "Mobility Assessment" . 

Set rst ■ New ADODB - Recordset 'create recordset object . 

rst.CursorXiOcation = adUseClient 

LoadControlsItems cboStaffs, False . 'Add every description from database to combobox oi 

tbox 

* 

Set rstMobility = New ADODB. Recordset 

rstMobility.CursorLocation = adUseClient , n - 

rstMobility.Open "Select * From MobilityAssessments Where ConsumerlD - ^ CustomerlD & ^ 

• And Agency = •" & AgencyCode & ■ ■ And Episode = " & Episode & And CaseNumber - i 
CaseNumber & 0 • And Intervention^ = '014 1 Order By Assessment Sequence DESC , cnn, _ 
adOpenKeyset, adLockOptimistic 

With rstMobility 

txtRecordNo = .RecordCount nf „,» -,„ d it t , 

If Not ( .EOF And .BOF) Then 'Hav.e record for this client and load it t< 

m . . * 

txtCurrentRecord = .AbsolutePosition 

txtSequencyNo = I (AssessmentSequence) 

LoadDataToControls rstMobility, IstDestinations, False 
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LoadDataToControls rstMobility, cboStrategiesLearning, False 
LoadDataToControls rstMobility, cboStaffs, False 
LoadDataToControls rstMobility, txtAssessment, True 
LoadDataToControls rstMobility, chkGoals, True 
LoadDataToControls rstMobility, cboYesNo,- True 
LoadDataToControls rstMobility, cboAgree, True 
LoadDataToControls rstMobility, cboExternal Services, True 
LoadDataToControls rstMobility, cboAgencyServices, True 
LoadDataToControls rstMobility, cboEquipment , True 
T,oadDataToControls rstMobility, cboServiceLevel , True 
LoadDataToControls rstMobility, cboObserveResponse, True 
LoadDataToControls rstMobility, cboConsumerRating, True 
LoadDataToControls rstMobility, cboRating, True 
LoadDataToControls rstMobility, cboDif f iculty, True 
LoadDataToControls rstMobility, cboFactors, True 

If .RecordCount > . AbsolutePosition Then cmdNext . Enabled = True" 

If J [FinishDateJ <> "12:00:00 PM n And IsDateM [FinishDate] ) Then 

cmdSave . Enabled = False 

cmdPrint . Enabled = True 

cmdclear . Enabled = True 
JBnd If 

If .RecordCount <= 1 Then 
♦ CTidNExt Record. Enabled = False 

cmdPreviousRecord. Enabled = False 
Elself .RecordCount >= 2 Then 

cmdPreviousRecord. Enabled = False 

cmdNExtRecord. Enabled = True 
End If 
Else 

cmdNExtRecord . Enabled = False 
cmdPreviousRecord. Enabled = False 
txt Cur rent Record = 0 
End If 
End With 

tabMobility.Tab = 0 * 
txtConsumerName . SetFocus 
Exit Sub 

Errhandler: 1 * 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 

End Sub 

Private Sub FormJCJnload (Cancel As Integer) 
Dim response As Integer 

If isFileDateChecked Then 

If rst. State » adStateOpen Then rst. Close 

Set rst = Nothing 

tabMobility.Tab = 0 

Set frmMobility = Nothing 
Else 

If Trim(txtAssessment (0) ) = "" And cmdSave . Enabled Then 

response = MsgBox("Have you finished O&M Assessment ?", vbQuestion + vbYesNo, "File Dat 
If response = vbYes Then 

MsgBox "Please enter the File Date !", vbOKOnly, "File Date" 

txtAssessment { 0 ) . SetFocus 

Cancel = True 
Else 

If rst. State = adStateOpen Then rst. Close 
Set rst = Nothing / 
tabMobility.Tab = 0 
Set frmMobility = Nothing 
End If. • 

Elself isDate (Trim ( txtAssessment (0))) And cmdSave . Enabled Then 

response =. MsgBox("Are you sure you finished the 6&M Assessment?", vbQuestion + vbYesNc 
ile Date") 
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• "response = £SxrM~»e use save button to to save the assessment information- . vbOR 

ly, "File Date") 

cmdSave . Set Focus 
Elself cmdSave. Enabled = True Then 
txtAssessment (0) = "° 

Elself IsDate(Trim<txtAssessment<0))> And Not cmdSave . Enabled Then 
If rst. State = adStateOpen Then rst. Close 
Set rst - Nothing 
tabMobility.Tab = 0 

Set frmMobility = Nothing . < . 

End If 
End If 
End Sub 

Private Sub cmdFactors_Click( ) 
Dim response As Integer 

respoSse^^So^-Rate on a scale of -3 to -3 where- ft Chr<13> ft Chr(10) ft ' 
response Ms^ < I ^ & significant decrease in training time" ft gr(13)ft Chr(10) ft _ 
»-2 will require a moderate decrease in traxnxng time" ft £hr < 13 ) ft Cnr ( 10 ) ft _ 
--1 will require a minimal decrease in training time" ft Ch*<13> ft ChrCIO) ft _ 
-0 will have no impact on training time- ft.Chr(13) .ft ChrUO) ft _ rhr(1(n & 
-+1 will require a minimal increase in traxnxng time » ft Chr<13) * C £F 
»+2 will require a moderate increase in training time- ft Chr(13) ft Chr{10) & _ 
'•+3 will require a significant increase in training time", vbOKOnly. _ • 
-Additional Factors") 
If response = vbOK Then 
v. tabMobility.Tab = 8 

cboFactors(O) .SetFocus 
End If 
End Sub 

2^42tT^?3^^~ vision devices do you use, (Self -reported. May choose more 

an one) " , _ 1 
vbOKOnly, "Glass or LV Devices" 

End Sub 

l^'i? J ^SrS^°^TlL a ^t. Problem, inform consumer and record their response 

vbOKOnly, "Observer, and Inform Comsumer" 
End Sub • 

Private Sub cmdGoal_Click( ) 
Dim response As Integer 

IsGoalsClicked = True 

JS3Sii i - Y W«(-Ba.«l on the assessment, the following goals are recommended.-, _ 

vbOKOnly, "Goals") 1 
If response = vbOK Then 

tabMobility.Tab =.9 

chkGoals ( 0 ) . SetFocus 

CountGoals 

End If 

•IsGoalsClicked = False 
End Sub 

Private . Sub cmdObservelnf ornL_Click ( ) . * 

Dim response As Integer 

MsgBox "If problem affects safety, indicate problem, inform consumer and record their respons 
vbOKOnly, "Observe and Inform Consumer" 
tabMobility.Tab =6 
cmd0bserveTrain(9) .SetFocus 
tabMobility.Tab ■ 7 
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cboYesNo(17) .SetFocus 
End Sub 

Private Sub cmdObserveInstruction_Click() 

MsgBox • Both the provider and consumer rate the following items & Chr(lO) & Chr{13) & Chr(13 

* ~ -When asking the consumer, use the standard 4 point rating scale for each questions & . 
pT;, n i fc chr(lO) ft « Great deal of difficulty 1° & Chr(13) ft Chr<10) ft _ 

« hr( Some Srficufty 2» ft Chr(13> ft Chr(lO) ft - Little difficulty 3- * Chr(13) | 

Chr<10) o & -. No difficulty 4- & Chr(13) & Chr(lO) ft - . Refuses . 4- ft Chr(13) ft Chr<13) ft C 

rU0) Provider use the standard 10 points scale: 1 - major problem, . 10 « no problem, N/A", _ 
vbOKOnly, "Observe and Train" 

f rmMobi 1 i ty . Re fresh 

tabMobility.Tab » 2 

tabMobility.Tab = 1 

cmdObserveTrain(O) .SetFocus 
End Sub 

Private Sub cmdObserveTrain_Click( Index As Integer) 

" SgBL = 4. T Sow much difficulty do you have walking with another person leading you?" ft Chrd 
& Chr{10) ( ^ f - no one gybing them, mark their response with a 1) " , _ 
vbOKOnly, "Self, assessment question" 
tabMobility.Tab = 2 
tabMobility.Tab = 1 
cboConsumer Rat ing { 9 ) . SetFocus 

E1S SBS d ^. = Hiw T Such difficulty do you have getting around your own home?-. vbOKOnly, _ 
"Self assessment question" 
tabMobility.Tab = 2 
tabMobility.Tab =1 
cboConsumerRat ing ( 8 ) . SetFocus 

ElS Ms^ *> you have asking questions if you're lost or «n"t find so, 

hing?", fc . „ 
vbOKOnly, "Self assessment question" 

tabMobility.Tab = 3 
tabMobility.Tab = 2 
cboConsumerRat ing (7) .SetFocus 

ElS MsgBox d «7. = How T ^h difficulty do you have going down steps-. vbOKOnly. "Self assessment * 
tion" 

tabMobility.Tab =4 
tabMobility.Tab = 3 
cboConsumerRat ing ( 6 ) . SetFocus 

ElS MsgBox d »8. = How T much difficulty do you have walking on a sidewalk?-. vbOKOnly. "Self assess* 

question" 

tabMobility.Tab « 4 
tabMobility.Tab = 3 
cboConsumerRating(5) .SetFocus 

Bl- £kS^/(Jo?Sne user only) How much difficulty do you have finding curbs or cracks in 
sidewalk with your cane?", vbOKOnly, "Self assessment question" 
tabMobility.Tab ■ 3 
tabMobility.Tab =4 
cboConsumerRa ting { 4 ). SetFocus 

^MsgBo^o! tFor^og guide users only) How mucb difficulty do you have travelling with and 
trolling your dog guide?", vbOKOnly, "Self assessment question" 

tabMobility.Tab = 3 

tabMobility.Tab = 4 

cboConsumerRat ing ( 3 ) . SetFocus 

E18 Sbo^i: How^ch difficulty do .you have crossing safely?'. vbOKOnly, -Self assessment < 
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tion" 

tabMobility.Tab = 3 
tabMobility.Tab = 4 
cboConsumerRating (2 ) . SetFocus 
El self Index » 8 Then 

mcsctRox "12. When you're in an unfamiliar building, for example/ & _ 

MsgBox^ ^; t ™~ Q y a doctor . s office, how much difficulty to you have getting around safely?' 

vbOKOnly, ."Self assessment question" 
tabMobility.Tab « 6 
tabMobility.Tab = 5 
cboConsumerRating (1) .SetFocus 

ElS MsgaS d «i3T Lousing public transportation or para-transit, how much difficulty do you hav 
using this transportation by yourself", _ 
vbOKOnly* "Self assessment question" 

tabMobility.Tab =5 

tabMobility.Tab = 6 

cboConsumerRating(O) .SetFocus 
End If 
End Sub 

Private Sub lstDestinations_KeyUp(KeyCode As Integer, Shift As Integer) 
Dim i As Integer 

If KeyCode « vbKeyBack Then 

If IstDestinations.SelCount = 1 Then 

lstDestinations.Selected(lstDestinations.Iiistlndex) « False 

Elself IstDestinations.ListCount > 1 Then 

For i » IstDestinations.ListCount - 1 To 0 Step -1 % 
\ If IstDestinations. Selected (i) Then 

lstDestinatioiis.Selected(i) - False 
End If 
Next 
End If 
End If 
End Sub 

Private Sub txtAssessment_LostFocus (Index As Integer) ■ 
Dim response As Integer 

If CheckForTab Then 
If index = 6 Then 

tabMobility.Tab = 1 
Elself Index = 5 Then 

tabMobility.Tab =8 , 
End If 
End If 

If Index = 0 And CheckForTab Then 

If Trim(txtAssessment(0)) = "" And cmdSave .Enabled Then , v - Tri » pile Date 

response = MsgBox<"Have you finished O&M Assessment ?", vbQuestxon + vbYesNo, File Date 
If response = vbYes Then " n - a 

MsgBox "Please enter the File Date !", vbOKOnly, "File Date 
txt Assessment (0) • SetFocus 
End If . , , m . 

Elself lst)ate(Trim(txtAssessment(0))) And cmdSave . Enabled Then . . vbYesNo „ 

response = MsgBox ("Are you sure, you finish the O&M Assessment?", vbQuestion + vbYesNo, 

e Date") 

" Sg^x S «PleIse e ^seiave button to to save the Assessment information vbOKOnly. "B 

Date" 

cmdSave . SetFocus 
Else * 

txtAssessment (0) = " " 
find If 
End If 

IsFileDateChecked = True 
End If 
End Sub 
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Private Function getTabCaption (tablndex As Integer) As String 

Select Case tablndex 
Case 0 

getTabCaption = "A. Self Assessment 0 
Case 1 

getTabCaption = 'B. Observe And Train 0 

Case 2 ^ « a 

getTabCaption = "C. Observe And Train 0 

Case 3 

getTabCaption * °D. Observe And Train" 
Case 4 

getTabCaption « °E» Observe And Train" 
Case 5 

getTabCaption = °F, Observe And Train" 

Case 6 ' 
getTabCaption = "G. Observe And Train 0 

Case 7 

getTabCaption = "H* Observe And Inform" 
Case 8 

getTabCaption = "I • Learning Strategy and Factors" 

Case 9 " ' 

getTabCaption = "J. O&M Services Agreement" 

"• End Select 

End Function 

Private Sub CountScoreO 

Dim i As Integer 

Dim tmpValue As Integer 

Dim taskA As Long 

Dim taskB As Long 

Dim taskD As Long 

Dim taskE As Long 

Dim avgScore As Single 

If cboStrategiesLearning. List Index = -1 Then 
tabMobility.Tab = 8 
cboStrategiesLeaming . Set Focus 

MsgBox "You had to select one of items from Strategy Learning !" , - vbOKOnly, "Strategy Learn 
Exit Sub 
End If 

For i = 0 To cboFactors . Count - 1 

If cboFactors (i) .Listlndex = -1 Then 
tabMobility.Tab - 8 * 

cboFactors ( i) .SetFocus , nn fc 

MsgBox "You had to select one of items from Factors!", vbOKOnly, "Factors 
Exit Sub 
End If 
Next 

For i a 0 To cboDifficulty. Count - 1 • count the score for task A 

If cboDiff iculty(i) .Listlndex = -1 Then 

taskA = taskA + 4 
Else 

tmpValue * cboDif ficulty(i) .ItemData (cboDifficulty (i) .Listlndex) 

If tmpValue » 5 Then 'User select "Refused", count 1 for this item 

taskA = taskA + 1 
Else 

taskA = taskA + tmpValue 
End If 
End If - 
Next 

For i = 0 To cboConsumerRa ting. Count - 1 'count the score for task A 

If cboConsumerRating(i) -Listlndex = -1 Then 
taskA = taskA +4 

tmpValue = cboConsumerRating(i) . ItemData (cboConsumerRating(i) .Listlndex) 



•User select "Refused" 
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count 1 for this item 
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If tmpValue = 5 Then 
taskA = . taskA + 0 
Else 

taskA = taskA + tmpValue , 
.End If 
End If 
Next 

tmpValue =0 

For i = 0 To cboRating. Count - 1 'count the score for Task B 

If cboRating (i) .List Index = -1 Then 'user does'nt select one, count 10 for this xtem 

taskB = taskB +10 
Else 

tmpValue = cboRating(i) . I temData (cboRating <i) .Listlndex) 

If tmpValue = 11 Then 'User select "Refused", count 1 for this item 

taskB = taskB + 1 
Else 

taskB = taskB + tmpValue 
End If 
End If 
Next 

taskD » cboStrategiesLearning . ItemData (cboStrategiesLearning . Listlndex) 
tmpValue =0 

For i = 0 To cboFac tors. Count - 1 

Select Case cboFac tors (i) . ItemDat a (cboFac tors (i) -Listlndex) 

Case -3: tmpValue = 120 

Case -2: tmpValue = 110 
" Case -1: tmpValue « 105 

Case 0: tmpValue « 91 

Case 1: tmpValue = 80 

Case 2: tmpValue = 60 

Case 3: tmpValue = 25 
End Select 

taskE = taskE + tmpValue 
Next 



txtProviderScore = Trim(taskB * 0.23) 
txtConsumer Score = Trim (taskA * 1.78) 

avgScore = ( (taskA * 1.78) + (taskB * 0..23) + taskD + (taskE / 5) ). / 4 

txtAssessment (3) = CLng (avgScore) 

txtAssessment (9) = Format(taskA * 1.78, "##") 

txtAssessment (10) = Format ((( taskB * 100) / 440), "##")' 

txtAssessment (11) = Format (taskD, "##") 

txtAssessment (12) - Format (taskE / 5, °##") 

txtAssessment (13) = Format (avgScore, "ft") 



Select Case CLng (avgScore) 



txtAssessment (1) 
txtAssessment (1) 
txtAssessment (1) 
txtAssessment (1) 



■ Level 3° 
"Level 2° 
"Level 1° 

"No Service Needed" 



Case 0 To 60: 
Case 61 To 80: 
Case 81 To 90: 
Case 91 To 100: 
End Select 
End Sub 

Private Sub tabMobility_Click(PreviousTab As Integer) 
Dim i- As Integer 

If tabMobility.Tab =» 0 Then 
cboStaf fs. SetFocus . 

frmMobility. Caption = "A. Self Assessment" 
Elself tabMobility.Tab = 1 Then 

cmdObserveln st ruction. SetFocus 

frmMobility. Caption = "B. Observe And Train" 
Elself tabMobility.Tab « 2 Then 

cboRating (37) .SetFocus 

frmMobility. Caption = "C. Observe And Train" 
Elself tabMobility.Tab = 3 Then 
cboRating (27) .SetFocus 
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frmMobility. Caption = "D. Observer And Train" 
Elself tabMobility.Tab « 4 Then 
cmaobserveTrain(5) .SetFocus 

frmMobility. Caption = °E. Observer And Train" 
Elself tabMobility.Tab = 5 Then 

cboRating( 14) .SetFocus * 

frmMobility. Caption = U F. Observer And Tram" 
Elself tabMobility.Tab = 6 Then 

cmdObserveTrain ( 0 ) . SetFocus 

frmMobility. Caption = fl G. Observer And Train" 
Elself tabMobility.Tab = 7 Then 
cmdObservelnform. SetFocus 

frmMobility. Caption = W H. Observer And Inform Consumer 0 
Elself tabMobility.Tab = 8 Then 

cboStrategiesLearning. SetFocus , „ 

frmMobility. Caption = °I. Learning Strategies, Factors and Recommended Service Level 
Elself tabMobility.Tab = 9 Then 
If Not IsGoalsClicked Then 
cmdGoal . SetFocus 
' frmMobility. Caption = "J. Services Agreement" 

If cboServiceLevel(O) .List Index = -1 Or cboServiceLevel (0) .List Index = 0 Then 

txtAssessment (14) = " " 
Else 

cboTimeFrame . List Index = cboServiceLevel (0) .List Index - 1 
txtAssessment (14) = cboTimeFraifte . Text 
Call CountGoals 
End If 
End If 
End If 
End N Sub 

Private Sub txtAsses sment_Vali date (Index As Integer, Cancel As Boolean) 

if Index = 2 Or Index = 7 Or Index = 0 Then 
If Trim (txtAssessment (Index) ) <> " u Then 

If Not IsDate(Trim(txtAssessment (Index) ) ) Then 

MsgBox "Please enter date into this field 1°,. vbOKOnly, "Date" 
txtAssessment (Index*) = 0 " 
Cancel = True 
End If 
End If 
End If 
End Sub 

Private Sub tx tCurrentRecord_Lost Focus ( ) 

If CheckForTab Then 
cboStaffs. SetFocus 

frmMobility. Caption = "Self Assessment" 
End If 
End Sub 

Private Sub CountGoals {) 
Dim i As Integer 

* 

For i = 0 To cboAgree . Count - 1 

Select Case i - 
Case 0 To 5 

If cboAgree (i) .Text = "Yes" Then chkGoals(lO) =1 
Case 6 To 8 

If cboAgree (i) .Text = "Yes" Then chkGoalsO) = 1 
Case 9 To 16 

If cboAgree (i)\ Text = "Yes" Then chkGoals(8) =1 
Case 17 

If cboAgree (i) .Text = "Yes" Then chkGoals(7) = 1 
Case 18 To 19- 

If cboAgree (i) ..Text = "Yes" Then chkGoals(6) f 1 

Case 20 To 25 

If cboAgree (i) .Text » "Yes" Then chkGoals(S) = 1 
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Case 26 

If cboAgree(i) .Text = "Yes" Then chkGoals(4) = 1 

Case 27 To 34 

If cboAgree(i) .Text = "Yes" Then chkGoals(3) = 1 

Case 35 

If cboAgree(i) .Text » "Yes" Then chkGoals(2) =1 
Case 36 To 41 

If cboAgree(i) .Text = "Yes" Then chkGoals(l) =1 
Case 42 To 43 

If cboAgree(i) .Text = "Yes" Then chkGoals(O) - 1 

End Select 
Next 
End Sub 



tOverallScore - 1 60^3970S «.OJ-JL3 

Option Explicit 

Private rsScores As ADODB. Recordset 

Private Sub FonuLoadO 

Dim PreSelf As Single 

Dim PreProv As Single 

Dim PreServiceScore As Single 

Dim PostSelf As Single 

Dim PostProv As Single 

Dim PostServiceScore As Single 

Dim PercentChange As Single . 

Dim AssessmentText < 5) As String 

Dim Interventions (5) As String 

Dim Numlnterventions As Integer 

Dim NoScores As Integer 

Dim Rating(5) As Integer 

Dim NumGoals As Integer 

Dim x As Integer 

Dim tmpValue As Double . 

AssessmentText(O) = "MobilityAssessments" 
AssessmentText (1) = " ILAssessment ■ 
AssessmentText (2). = "SocialAssessment" 
AssessmentText (3) = "Employment Assessment 0 
AssessmentText (4) = "Computer Assessment" 

InterventionlD(O) = "014" 1 Mobility 

InterventionlD(l). = "013" 1 Independent Living 

Interventions (2) - "010" ' Social Service 

Interventions (3) = "050" ' Employment 

InterventionID{4) = "160" 1 Computer Skills 

/ PreService - Self -Assessment Component - TaskA & TaskB from Assessments - Al 
Set rsScores = New Recordset 

^rsScores. Open "SELECT TaslcA, TaskB PROM 0 & AssessmentText (x) & " WHERE Consumerld = & Cust 

erlD & " AND Episode « ° & Episode & _ r n t n ^ 

" AND Agency = ■ B & AgencyCode & n * AND CaseNumber = 1 ° & CaseNumber & , cm 

adOpenForwardOnly, adLockReadOnly 
With rsScores 

If Not (-EOF And -BOF) Then 

If (! [taskA] <> 1,0 And ! [taskB] <> ■/) Then " 
PreSelf = PreSelf + CInt ( I [taskA] ) 
PreProv = PreProv + CInt ( ! [taskB] ) 

BlS NoSc t ores « NoScores + 1 1 Assessments that. have no scores, i.e. No service pro^ 

ed 

End If 
. MoveNext 
End If 
End With 

x = x + 1 
rsScores .Close 
Wend 

• Total number of Interventions for the consumer 

Set rsScores = New Recordset . . _ - - _ 

rsScores. Open 0 SELECT count { Interventions) as IntTotal FROM Interventions WHERE Consumerld - 
Customers & 0 AND Episode = n & Episode & 

■ AND Agency = ,D & AgencyCode & n 1 AND CaseNumber = & CaseNumber & cnn, 
penForwardOnly, adLockReadOnly 
With rsScores 

If Not (.EOF And .BOF) Then 

Numlnterventions = ! [IntTotal] 



End If 
End With 

rsScores. Close 

Set rsScores = Nothing 

If Numlnterventions > 5 Then 1 Remove Non-Assessment Interventions 

Numlnterventions = 5 
End If 

Numlnterventions' = Numlnterventions - NoScores • Remove Interventions that have no Assessment 
ore 

PreSelf = PreSelf / Numlnterventions 



1 Social questions from End of Episode QA 
tmpValue = 0 

tmpValue = frmEndOf Episode. cboActivity. ItemData ( frmEndOf Episode . cboActivity . Listlndex) 
tmpValue = tmpValue + frmEnd0fEpisode.cboFrequency2 -ItemData (frmEndOf Episode. cboFrequency2 . Lis 
dex) 

tmpValue « tmpValue * 12.5 
PreSelf - (PreSelf + tmpValue) / 2 

* Calculate Preservice Provider Component - All 
PreProv = PreProv / Numlnterventions 
PreServiceScore = (PreSelf + PreProv) / 2 

txtPreScore = PreServiceScore 



' Post Service - Self -Assessment Component - BI 
tmpValue = 0 

tmpValue = frmEndOf Episode . cboActivity . ItemData ( frmEndOf Episode . cboActivity . List Index) 
tmpValue ■ tmpValue + frmEndOf Episode . cbdFrequency2 . ItemData (frmEndOf Episode. cboFreouency2 . Iiis 
dex) 

tmpValue = tmpValue + frmEndOf Episode. cboEf feet . ItemData (frmEndOf Episode. cboEf feet .List Index) 
PostSelf = tmpValue * 8.33 



• Post Service - Provider's Determination of Functioning - BII 
NumGoals = 0 

tmpValue = 0 

• Add the goal ratings for a particular intervention 
x = 0 

While (x <> 5) 
Rating (x) = 0 

X a X + 1 

Wend 

x = 0 . . 

While (x <> 5) 

Set rsScores =.New Recordset 

rsScores. Open ■ SELECT . Achievement FROM Goal Achieve .WHERE Consumer Id- = 0 & CustomerlD & w AND 
isode = ■ & Episode & _ 

n AND Agency = ' ° & AgencyCode & ■ 1 AND GaseNumber = ■ " & CaseNumber & * ■ • ■ & _ 
0 AND Intervention^ = • ■ . & InterventionlD(x) & ■ ■ ■ , enn, adOpenForwardOnly, ad 
kReadOnly y 
With rsScores 

If Not (.EOF And .BOF) Then 

Rating(x) = Rating(x) + ! (Achievement] . • Add up the ratings for each intervention ( 

. rating(O) =* Mobility, rating(l) « IL, etc.) 

NumGoals = NumGoals + 1 1 Total number of goals 
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End If 
End With 

x = x + 1 
Wend 

rsScores .Close 

Set rsScores = Nothing 

x «'0 

While <> 5) . Divid e each intervention goal ratings 1 by 10 J 

SS313 : KS8 / JS-o— * 4 > 1 Divide each interv ention 9oal rating * (to 

1 number of goals * 4) 

x = x + 1 

Wend 



PostProv = Rating(O) + Rating (1) + Rating(2) + Rating(3) + Rating(4> 
PostProv = PostProv / Numlnterventions 
PostServiceScore = (PostSelf + PostProv) /.2 
txtPostScore = PostServiceScore 



• Percent Change 
tmpValue = 0 

tmpValue » PostServiceScore - PreServiceScore 
tmpValue = tmpValue / PreServiceScore 
tmpvalue = tmpValue * 100 

txtFunctionalChange = tmpValue * . 
End Sub 

Private Sub Commandl_Click( ) 

Unload Me 
End Sub 
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Option Explicit 

Dim rst Payer As ADODB. Recordset 

Dim rstlnterventions As ADODB . Recordset 

Dim rstLocations As ADODB , Recordset 

Dim rstStartDate As ADODB . Recordset 

Dim rstAuth As ADODB. Recordset 

Dim IndexNo. As Integer 

Dim interyentionSequence As Long 

Dim PayerSequence As Long 

Dimj As Integer 

Dim k As Integer 

Dim x As Integer 

Dim IsNewPayer As Boolean 

Dim isNewAuth As Boolean 

Dim SaveFlag As Boolean inn prf finds out how many we ne< 

Dim InterventionSeq(lOO) As Long - Temporarily assign 100 until Ed finds ouc now y 

Dim interventionDesc(lOO) As String 

Dim tmpID As String 

Dim tmpAuthStartDate As Date 

Dim trapAuthgndDate As Date 

Dim UnloadFlag As Boolean 

Private Sub cboInterventioncodes_KeyUp (KeyCode As Integer, Shift As Integer) 
If KeyCode » vbKeyBack Then 

cboInterventionCodes.Listlndex = -1 • 

End If 
End Sub 

Private Sub cboInterventionCodes_LostFocus { ) 
If cboInterventionCodes.Listlndex <> -1 Then 

' Find the Intervention Sequence number by the Description 

For x = 0 To 99" 

If interventionDesc(x) = cbo Int erven tionCodes .Text Then 
InterventionSequence = InterventionSeq(x) 
Exit For i 
End If ' 
Next 

• Display the Start Date for the Intervention 

Set rstStartDate » New ADODB. Recordset - 
rstStartDate. CursorLocation = adUseqlient 

rstStartDate. Open "Select StartDate From Interventions & _ n^m^nrfe & 

rStb a " P - Where Consumerld = ■ & CustomerlD & • And Agency = - • & AgencyCode & 

& " ' "And CaseNumber = ; - & CaseNumber. & • • Ana Episode = tt & ^ is ^® * ; 

• And InterventionSequence = ■ & InterventionSequence, cnn ( adOpenDy: 

c, adLockdptimistic 

With rstStartDate 

txtStartDate » ! [StartDate] 
End With 

rstStartDate .Close 
Set rstStartDate = Nothing 
. End If 

End Sub 

Private Sub cboPayerLocation_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboPayerLocation.Listlndex = -1 

End If 
End Sub 

Private Sub cboPayers_click( ) 



1 clear data in all fields 

If cboPayers.Listlndex « -1 Then 
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clearData cboPayerLocation, False 
txtlDWithPayer = n 0 
txtPayerContact = " d 
txtPayerPhone = 1,0 
isNewPayer = True 
txtAuthTotal = 0D 
txtAuthorizationID = "* 
clearData cboInterventionCodes , False 
txtAuthStartDate « 0 n 
txtAuthEndDate = 0 " 
txtStartDate - nu 
End If 

If cboPayers. List Index <> -1 Then • Display the locations for the payer that was selectee 

DisplayJLocation 
End If 

End Sub 

Private Sub cboPayersJKeyUp(KeyCode As Integer, Shift As Integer) 
. If KeyCode = vbKeyBack Then 
cboPayers. Li st Index = -1 
End If 
End Sub. 

Private Sub cmdClose_Click() 

Set rstPayer « Nothing 

Set rstAuth - Nothing 

Unload Me 
End Sub 

Private Sub cmdNewAuth^_Click() 

1 Clear data in the Authorization fields 
txtAuthorizationID = ■ 0 
clearData cboInterventionCodes, False 
txtStartDate = no 
txtAuthStartDate 
txtAuthEndDate 

• Disable all navigation buttons except Save Payer and Intervention 
cmdPreviousAuth. Enabled = False 
cmdNextAuth. Enabled = False - 
■ cmdNewAuth. Enabled - False 
cmdPrevious Payer. Enabled = False 
cmdNextPayer. Enabled = False 
cmdNewPayer . Enabled = False 
cboInterventionCodes. Locked « False 

txtAuthorizationID. SetFocus 
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IsNewAuth = True 



End Sub 

Private Sub cmdNewPayer_Click ( ) 

• Clear all data in all fields 

clearData cboPayers, False 

clearData cboPayerLocation, False 

txtlDWithPayer » aw 

txtPayerContact = nn 

txtPayerPhone = no 

IsNewPayer = True 

txtAuthTotal = nw 

txtAuthorizationID = ow 

clearData cboInterventionCodes, False 

txtAuthStartDate = a u 

txtAuthEndDate = n 0 

txtStartDate = 0 ■ 
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' Disable all navigation buttons except Save Payer 

cmdPreviousAuth. Enabled = False 

cmdNextAuth ..Enabled = False 

cmdNewAuth. Enabled - False 

cmdPreviousPayer . Enabled - = False 

cmdNext Payer . Enabled = False 

cxndNewPay er . Enabled » False 

cboIhterventionCodes. Locked = False 

» Enable data fields 

cboPayers. Enabled ■ True 

cboPayerLocation. Enabled = True 

txtlDWithPayer. Enabled = True 

txtPayerContact. Enabled = True , 

txtPayerPhone . Enabled « True 

txt Authorization^. Enabled = True 

cboInterventionCodes. Enabled = True 

cboPayers . SetFocus 

End Sub 

Private Sub cmdNextAuth_Click ( ) " 
SaveRecords 

IsNewAuth = True * 

With rstAuth 

If Not (.BOF And .EOF) Then 
. MoveNext 

txtAuthorizationlD = t [ Author izationID] 
txtAuthTotal' o .RecordCount 

LoadDataToControis rstAuth, txtAuthStartDate , False 
LoadDataToControls rstAuth, txtAuthEndDate, False 
InterventionSequence o i [InterventionSequence] 
IsNewAuth - False i 
End If 

x - o ' Highlight the saved Intervention in . the combo box 

For x = 0 To 99 

If InterventionSequence = In t erven tionSeq(x) Then 
cboInterventionCodes. Listlndex = x 

End If 
Next 

1 Refresh the StartDate for the Intervention . 

If InterventionSequence <> 0 Then 

Set rstStartDate - New ADODB . Recordset 
rstStartDate. CursorLocation = adUseClient 

rstStartDate. Open -Select StartDate From Interventions * & _ 

n Where Consumerld = n & CustomerlD & ■ And Agency = ' " & AgencyCode ; 

~ ■ And CaseNumber » • " & CaseNumber & n ' And Episode = 0 Sc Episode & 

■ And InterventionSequence = ° & InterventionSequence, cnn, adOpenD; 

c , adLockOptimistic 

With rstStartDate 

txtStartDate « 3 [StartDate] 
End With 

rstStartDate .Close 
End If • ' 

1 Enable/Disable authorization navigation buttons according!^ 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousAuth . Enabled == False 
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cmdNextAuth . Enabled = True 

cmdNewAuth . Enabled = False 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousAuth , Enabled = True 

cmdNextAuth . Enabled = True 

cmdNewAuth . Enabled = False 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousAuth . Enabled = True 

cmdNextAuth. Enabled = False 

cmdNewAuth. Enabled = True 
End If 
End If 
End With 



txtAuthorizationlD. SetFocus 
End Sub 

Private Sub cmdNextPayer_Click {) 

SaveRecords 

With rstPayer 
.MoveNext 

PayerSeguence = ! [Payer Sequence] . 

LoadDataToControls rstPayer, txtPayerContact, False 

LoadDataToControls rstPayer , txt Payer Phone , False 

LoadDataToControls rstPayer, txtlDWithPayer, False 

LoadDataToControls rstPayer, cboPayers, False 

■ Enable and disable navigation buttons accordingly 

If .RecordCount >=* 1 Then 

If .AbsolutePosition = 1 Then 

cmdPrevi ous Payer . Enabled = False 
. ' cmdNextPayer . Enabled » True 
■ cmdNewPayer. Enabled = False 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousPayer . Enabled = True 
cmdNextPayer . Enabled = True 
cmdNewPayer. Enabled = False 
Elself .RecordCount = .AbsolutePosition Then 
cmdPreviousPayer. Enabled = True 
cmdNextPayer .Enabled = False 
cmdNewPayer. Enabled = True 
End If 
End If 

fend With 

1 Load the- location codes and descriptions for the payer that was saved 

cboPayerLocation .Clear 

Set rstLocations - New ADODB. Recordset 
rstLocations. CursorLocation = adUseClient 

rstLocations. Open "Select Code, Description From PayerLocation" & _ 

w Where Payer ID. = 1 0 & cboPayers . I temData (cboPayers .Lis tlndex) & 0 1 n , cnn, 
enDynamic, adLockOptimistic 

With rstLocations 
.MoveFirst 
While Not (.EOF) 

cboPayerLocation. Aqidltem ! [Description] 

cboPayerLocation . ItemData (cboPayerLocation .Newlndex) « ! [Code] 
.MoveNext 
Wend 
End With 
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• Display the liocation that was saved 

Set rstLocations = New ADODB. Recordset 
rstLocations . Cur sorLocat ion = adUseClient 

rstLocations. Open "Select PayerLocation From Payerlnfo" & _ 

■ Where Consumer Id = ■ & Customer ID & ■ And Agency = 1 w & AgencyCode & 
n And CaseNumber = • 0 & CaseNumber & ° ' And Episode = 0 & Episode & _ 
" And PayerlD a 1 " & cboPayers . I temData(cboPayers. Listlndex) & 01 °/ cnn, 
penDynamic, adLockOptimistic 

With rstLocations 
,MoveFirst 

While Not (.EOF) 

If Trim( I [PayerLocation] & vbNujLlString) = *" Then 

cboPayerLocation. List Index » -1 
Else 

For j - 0 To cboPayerLocation.ListCount - 1 

If cboPayerLocat ion . I temData ( j ) = ! [ PayerLocation] Then 
k = j 
Exit For 
End If 
Next 

cboPayerLocat ion. Listlndex = k 
End If 
.MoveNext 
Wend 
End With 

rstLocations .Close 



• Authorization Section 
IsNewAuth = True 

Set rstAuth = New ADODB . Recordset 
rstAuth.CursorLocation = adUseClient 

rstAuth. Open « Select * From PayerAuth Where ConsumerlD = n & CustomerlD & And Agency = 
encyCode & 0 ■ And CaseNumber = ' ° &• _ 

CaseNumber & 01 And Episode = ■ & Episode & 

a And PayerSequence = n & PayerSeguence & ■ Order By PayerAuthSequence" , cnn, 
npynamic, adLockOptimistic 

With rstAuth 

If Not ( . BOF And .EOF) Then 
.MoveFirst 

txtAuthorizationID - ! [Authorizations] 
txtAuthTotal = .RecordCouht 

LoadDataToControls rstAuth, ' txtAuchStartDate, False • 
LoadDataToControls rstAuth, txtAuthEndDate , False 
InterventionSequence = ! [InterventionSequence] 
IsNewAuth = False 
End If 

x - 0 ' Highlight the saved Intervention in the combo box 



For x =s 0 To 99 

If InterventionSequence = InterventionSeq(x) Then 
cboInterventionCodes. Listlndex « x 

End If 
Next 

• Refresh the StartDate for the Intervention 

If InterventionSequence- <> 0 Then 

Set rstStartDate = New ADODB . Recordset 
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rstStartDate. CursorLocation = adUseClient 
rstStar t Date.Qpen -Select St^ate^ ^entions- * ^ ^ = ,„ & AgencyCode & .. 

& - "And CaseNumber = " & CaseNumber & - And Episode = '^f^ 

And InterventionSequence = " & mterventionSequence, cnn, adOpenDyna* 

c, adLockOptimistic 

With rstStartDate 

txtStartDate = ! [StartDate] 
End With 

rstStartDate . Close 
End If 

• Enable/Disable authorization buttons according to how n*ny records we found in the records, 

• Remember we are always looking at the first authorization for the payer 

" ir!^so!u?ePos;tIor= I And .RecordCount - I *hen ■ Dust one record in the recordset 
cmdPreviousAuth .Enabled = False 
' cmdNextAuth. Enabled = False 
cmdNewAuth. Enabled = True Mft „. than one record in the r 

Elself .AbsolutePosition « 1 And . RecordCount > 1 Then More than one rec^ 

ordset 

cmdPreviousAuth. Enabled = False 
cmdNextAuth .Enabled = True 

Biself^sSuSlos^ion^rAnd .AbsolutePosition = .RecordCount Then. .< At the end" of 

e recordset 

cmdPreviousAuth. Enabled » True 
cmdNextAuth. Enabled = False 
cmdNewAuth. Enabled = True 
End If 
End If 

End With 

cboPayers . SetFocus 
End Sub 

Private Sub cmdPreviousAuth_Click( ) 

SaveRecords 

IsNewAuth = True 

With rstAuth 

If Not ( . BOF And . EOF) Then 
.MovePrevious 

txtAuthorizationID » ! [ Author! zationID 3 
txtAuthTotal = .RecordCount n 
LoadDataToControls rstAuth, txtAuthStartDate, False 
LoadDataToControls rstAuth, txtiAuthEndDate , False 
InterventionSequence = ! [InterventionSequence] 
IsNewAuth - False 
End If 

x m o • Highlight the saved Intervention in the combo box 

For x = 0 To 99 • 
If InterventionSequence = InterventxonSeq(x) Then 
cboInterventionCodes.lAstlndex = x 

End If 
Next 

• Refresh the StartDate for the Intervention 
If InterventionSequence <> 0 Then 
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Set rstStartDate = New ADODB. Recordset 
rltStartDate.CursorLocation = adusedient 

rstStartnate.Open -Sjgjct Starve. Fro. Intentions- ft ^ ^ = , „ & AgencyCode & ■ ■ 

0 And CaseNumber - ft CaseNumber ft ^^^ce ^L^adOplnlorwa 
• And mterventionSequence = • ft interventionSequence, cnn, ^ 



dOnly, adLockReadOnly 
With rstStartDate 

txtStartDate = ! (StartDate3 
End With 

rstStartDate . Close 
End If 

• Enable/Disable authorization navigation buttons accordingly 

If .RecordCount = 1 And . Absolut ePos it ion = 1 Then 
cmdPreviousAuth. Enabled = False 
cmdNextAuth. Enabled = True 
cmdNewAuth. Enabled = True 

End If . 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousAuth -Enabled = False 
cmdNextAuth. Enabled = True 
cmdNewAuth. Enabled = False . 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousAuth. Enabled = True 
cmdNextAuth. Enabled = True 
cmdNewAuth. Enabled = False , 
Elself .RecordCount = .AbsolutePosition Then 
cmdPreviousAuth. Enabled = True 
cmdNextAuth. Enabled = False 
cmdNewAuth. Enabled =» True 
End If 
End If 
End With 

txtAuthorizat'ionID . SetFocus 
End Sub 

Private Sub cmdPreviousPayer__Click ( ) 
SaveRecords " 

With rstPayer 

.MovePrevious 

Payer Sequence = i [Payer Sequence] 

LoadDataToControls rstPayer, txt Payer Contact, False 
LoadDataToControls rstPayer. txt Payer Phone, False 
LoadDataToControls rstPayer, txtlDWithPayer, False 
LoadDataToControls rstPayer, cboPayers, False 

' Enable and disable navigation buttons accordingly 

If .RecordCount >= 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousPayer. Enabled = False 

cmdNext Payer. Enabled = True 

cmdNewPayer. Enabled = False 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousPayer. Enabled = True 

cmdNextPayer . Enabled » True 

cmdNewPayer .Enabled = False 
Elself .RecordCount = .AbsolutePosition Then 
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End With 

1 Load the location codes and descriptions for the 'payer that was saved 

cboPayerLocation . Clear 

Set rstLocations = New ADODB . Recordset 
rstLocations. CursorLocation = adUseClient 

rstLocations. Open "Select Code, Description From PayerLocation" & _ 

" Where Payer JD = * 0 & cboPayers . ItemData(cboPayers .Listlndex) & n • n , cnn, 
enDynamic, adLockOptimistic 

With rstLocations 
.MoveFirst 
While Not (.EOF) 

cboPayerLocation.AddXtem ! (Description] 

cboPayerliOcation . ItemData ( cboPayerLocation .Newlndex) = ! [Code] 
.MoveNext 
Wend 
End With 

rstLocations. Close 

• Display the Location that was saved 

Set rstLocations = New ADODB. Recordset 
rstLocations. CursorLocation = adUseClient 

rstLocations. Open "Select PayerLocation From Payerlnfo" & _ 

B Where Consuraerld = " & CustomerlD & 0 And Agency *= ' " & AgencyCode' & " ' 

■ And CaseNumber = 1 " & CaseNumber & n 1 And Episode = ■ & Episode & _ 

■ And PayerlD - * B & cboPayers. ItemData (cboPayers .Li stlndex) & ° ,a , cnn 
penDynamic, adLockOptimistic 

i 

With rstLocations 
.MoveFirst 

While Not (.EOF) 

If Trim( I [PayerLocation] & vbNullString) = "* Then 

cboPayerLocation. List Index = -1 
Else 

For j = 0 To cboPayerLocation. Lis tCount - 1 

If cboPayerLocation. ItemData ( j) = I [PayerLocation] Then 

* » j 
Exit For 
End If 
Next 

cboPayerLocation. Listlndex = k 
End If 
. MoveNext 
Wend 
End With 

rstLocations . Close 



1 Authorization Section 
IsNewAuth = True 

Set rstAuth = New ADODB.. Recordset 
rstAuth.CursorLocation = adUseClient 

rstAuth. Open • Select * From PayerAuth Where ConsumerlD = ° & CustomerlD & " And Agency = 
encyCode & ■ ' And CaseNumber = ' ° & _ 

CaseNumber & . * • And Episode » ■ & Episode & _ 
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cmdPreviousPayer. Enabled = True 
cmdNext Payer .Enabled » False 
cmdNewPayer . Enabled = True 
End If 
End If 
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"And PayerSequence = ° & PayerSequence & ■ Order By PayerAuthSequence ■ , cnn, a< 
nDynamic, adLockOptimistic 

With rstAuth 

If Not (.BOF And .EOF) Then 
.MoveFirst 

txtAuthorizationID = ! [Authorization^ J 

txtAuthTotal = .RecordCount , 
LoadDataToControls rstAuth, txtAuthStartDate, False 
LoadDataToControls rstAuth, txtAuthEndDate , FaJ.se 
InterventionSequence = i [InterventionSequenceJ 
IsNewAuth =• False 
End If 

x « 0 ' Highlight the saved Intervention in the combo box 

For x = 0 To 99 

If InterventionSequence = InterventionSeq(x) Then 
cboInterventionCodes.Ijistlndex = x 

End If 
Next 

1 Refresh the StartDate for the Intervention 

If InterventionSequence <> 0 Then 

Set rstStartDate * New ADODB . Recordset 
rst StartDate. Cur sorLocat ion » adUseClient 

rstStartDate. Open "Select StartDate From Interventions" & _ 

0 Where Consumerld = w & CustomerlD & 0 And Agency = 1 ■ & AgencyCode & 

& _ 

" And CaseNumber = ' 0 & CaseNumber & ■ 1 And Episode » " & Episode & 
" And InterventionSequence = " & InterventionSequence, cnn, adOpenDy 

c, adLockOptimistic 

With rstStartDate 

txtStartDate = 1 [StartDateJ 
End With ... • 

rstStartDate. Close \ 
End If 

• Enable/Disable authorization navigation buttons accordingly 

If .RecordCount > 0 Then 

If .AbsolutePosition * 1 And .RecordCount « 1 Then 1 just one record in the recordse 
cmdPreviousAuth . Enabled » False 
\ cmdNextAuth. Enabled =» False 

cmdNewAuth . Enabled = True 
Elself .AbsolutePosition » 1 And .RecordCount > 1 Then ■ More than one record in the 

ordset 

cmdPreviousAuth . Enabled = False 

cmdNextAuth. Enabled = True 

cmdNewAuth . Enabled * False 
Elself .AbsolutePosition > 1 And .AbsolutePosition ■ .RecordCount Then ■ At the end c 
e recordset 

cmdPreviousAuth. Enabled = True 

cmdNextAuth. Enabled = False 

cmdNewAuth. Enabled = True 
End If 
End If 



End With 

cboPayers . SetFocus 
End Sub 

Private Sub .cmdSave_Click ( ) 



SaveRecords 
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If SaveFlag = True Then , nifnnlv o Save » 

MsgBox "Payer Information successfully saved! 0 , vbOKOnly, £>ave 

End If 
End ' Sub 

Private Sub SaveRecords ( ) 

. Dim tmpPayerlD As String 
Dim tmpLocation As String 
Dim tmpIDWithPayer As String 
Dim tmpContact As String 
Dim tmpPhone As String 
Dim tmpFinishDate As String 
Dim tmpPosition As Long 

On Error GoTo ErrorSave 

SaveFlag = True 

• Check all mandatory fields have values 

If cbo Payers .Li st Index = -1 Then ' 

MsgBox "Please select a Payer! « , vblnformation + vbOKOnly, Save 
cboPayers . SetFocus 
SaveFlag « False 
Exit Sub 

Else , 
tmpPayerlD = cboPayers; I temData( cboPayers. Lis tlndex) 

End If 

If cboPayerLocation . List Index = -1 Then ^ 

MsgBox "Please select a location!", vblnformation + vbOKOnly, "Payer 
cboPayerLocation . SetFocus^ 
SaveFlag = False 
Exit Sub . 

ElS tmpLocation = cboPayerLocation . ItemData (cboPayerLocation . List Index) 
End If 

If Trim(txtlDWithPayer) « "" Then 

tmpIDWithPayer « aa 
Else 

tmpIDWithPayer = txtlDWithPayer 
End If 

If Trim(txtPayerContact) = 00 Then 

tmpContact = "" 
Else 

tmpContact ■ txtPayerContact 
End If 

If Trim(txtPayerPhone) » * n Then 

tmpPhone = "" 
Else 

tmpPhone = txt Payer Phone 
End If 

If TrimUxtAuthorizationID & vbNullString) = " " Then 

MsgBox "Please enter a Authorization Number!", vbOKOnly, save 

txt AuthorizationID . SetFocus 

SaveFlag = False . 

Exit Sub 
End If 

If cboInterventibnCodes.Listlndex = -1 Then , nvnnlv no™,, 

MsgBox "Please select an intervention!", vblnformation + vbOKOnly, save 
cbointerventionCodes . SetFocus 
SaveFlag » False 
Exit Sub 



End If 

If Not isDate(Trim(txtAuthStartDate) > Then 
tmpAuthStartDate = °12:00:00 PM" 

E1 tmpAuthStartDate = txtAuthStartDate 
End If 

If Not isDate(Trim(txtAuthEndDate) ) Then 

tmpAuthEndDate = °12:00:00 PM° 
Else 

tmpAuthEndDate = txtAuthEndDate 
End If 



If isNewPayer = False Then ' The user updated a Payer record 



With rstPayer. 

! (Payer ID] = tmpPayerlD 

i [PayerLocation] =» tmpLocation 

! [IDWithPayer] = tmpIDWithPayer 

! [PayerContact] = tropContact 

! [Payer Phone] = tmpPhone 

.Update 
End With 

PayerSequence = rstPayer ! [PayerSequence] 
Else ■ inserting a record for the consumer 

With rstPayer 

.AddNew / 
! [consumer id] = Customer ID 
! (Agency) = AgencyCode 
! [CaseNumber] = .CaseNlAmber 
! [Episode] « Episode 
![ Payer ID] = tmpPayerlD 
! [Payertiocation] = tmpliocation 
■ [IDWithPayer] = tmpIDWithPayer 
! [PayerContact] = tmpContact 
! [PayerPhone] = tmpPhone 
.Update 
• End With 

rSSS:^- Select * From Payerlnfo Where •ConsumerlD = « U Customers «. - And Agency - ■ • 

AgencyCode * - ^ d ^ isode = - * Episode, cnn. adOpenDynamic . ad^ocXOptimis. 

rstPayer .MoveLast 

txtTptal = rstPayer . RecordCount 

PayerSequence = rstPayer ! [PayerSequence] 
With rstPayer 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousPayer. Enabled = False 

cmdNextPayer., Enabled = True 
Elself- .AbsolutePosition < .RecordCount Then 

cmdPreviousPayer. Enabled = True 

cmdNext Payer . Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousPayer. Enabled = True 

cmdNextPayer. Enabled = False 
End If 
End If 

If .RecordCount « 1 And .AbsolutePosition = 1 Then 
cmdPreviousPayer . Enabled = False 
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cmdNext Payer . Enabled = False 
cmdNewPayer. Enabled = True 
End If 
End With 

IsNewPayer = False 
IsNewAuth = True 

End If 

cboPayers . SetFocus 



• Update or Insert data to the Authorizations table 
If IsNewAuth = False Then 1 Update only 

With rstAuth 

i {Payer Sequence] = Payer Sequence » 
! [InterventionSequence] = InterventionSequence 
! [AuthorizationID] = txtAuthorizationID 
! [AuthStartDate] = tmpAuthS tart Date 
! [AuthEndDate] = tinpAuthEndDate 
.Update 
End With 

Else ■ Insert new record 

With rstAuth . ^ 

.AddNew 

! [consumer id] = Customer ID 
! [Agency] = AgencyCode 
! [CaseNumber] == CaseNumber 
I [Episode! = Episode 
! [Payer Sequence] =* Payer Sequence 
I [InterventionSequence] = InterventionSequence 
» [AuthorizationID] = txtAuthorizationID 
! [AuthStartDate] = tmpAutihStartDate 
! [AuthEndDate] = tmpAuthEndDate 
.Update 
End With 

rstAuth. Close 

' rstAuth. Open n Select * From PayerAuth Where ConsumerlD = n & CustomerlD & a And Agency = ■ ■ I 
AgencyCode & " ' And CaseNumber = ' " & _ 

CaseNumber & ■ " And Episode = n & Episode & _ 
"And PayerSequence « " & Payer Sequence , cnn, adOpenDynamic , adLockOptimistic 
r s t Au th . MoveLas t 

txtAuthTotal = rstAuth. RecordCount 

InterventionSequence. = rstAuth J ['InterventionSequence] 

With rstAuth 

If .RecordCount > 0 Then 

If .AbsolutePosition = 1 And .RecordCount = 1 Then 
cmdPreviousAuth . Enabled = False 
cmdNextAuth.Enab.led = False 
cmdNewPayer . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPreviousAuth v Enabled = True 
cmdNextAutih. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 
cmdPreviousAuth. Enabled = True 
cmdNextAuth. Enabled =. False 
End If 
End If 
End With 

IsNewAuth = False 
txtAuthorizationID . SetFocus 
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cradNewAuth . Enabled = True 

■ enable Payer navigation buttons accordingly 
With rstPayer 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousPayer. Enabled = False 
cmdNextPayer. Enabled = True 
cmdNewPayer . Enabled « False 
Elself . Absolut ePosit ion < .RecordCount Then 
cmdPreviousPayer. Enabled = True 
cmdNextPayer. Enabled = True 
cmdNewPayer . Enabled = False 
Elself .RecordCount = . Absolut ePos it ion Then 
cmdPreviousPayer. Enabled = True 
cmdNextPayer. Enabled = False 
cmdNewPayer .Enabled = True 
End If 
End If 
End With 

End If 

Exit Sub 

MsgBo^Err. Description, vbCrit'ical + vbOKCancel, "Save" 
End Sub 

Private Sub Display_Location ( ) 

• Load the location codes and descriptions for the payer that was saved 
cboPayerLocat ion . Clear 

Set rstLocations ■ New ADODB . Recordset 
rstLocat ions. CursorLocat ion = adUseClient , 

rstLocat ions. Open "Select Code, Description From PayerLocation & _ 

rstLocations. upen paye ^ ID m , „ & cb oPayers . I temData{ cboPayers : List Index) & " ' u , cnn, ac 

enDynamic , adLockOptimis tic 

With rstLocations 
.MoveFirst 
While Not (.EOF) 

cboPayerLocation.Addltem I (Description] ... . 

" cboPayerLocation.ItemData(cboPayerLocation.NewIndex) = I [Code J 

. MoveNext 
Wend . 
End With 

rstLocations .Close 

Set rstLocations = Nothing 

cboPayerLocation.Listlndex =0 'Set focus to the first item as a default 

End Sub 

Private Sub Form_Jboad<) 

• Consumer Information . 
txtConsumerName.Text = FirstName .& ■ n & LastName 
txtCaseNumber = CaseNumber 

txtEpisode * Episode 

• Load codes and descriptions for Payers 
LoadControlsStems cboPayers, False 

- Load intervention codes and descriptions for this consumer into the combo box 
IndexNo =0 
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cboInterventionCodes .Clear 

Set rstlnterventions = New ADODB . Recordset 
rstlnterventions.CursorLocation » adUseClient 

rstlnterventions. Open "Select Description, StartDate, InterventionSequence From InterventionCo 
IC, Interventions I ■ & _ 

"Where iC.Code = I . Int erven tionID ■ & _ 

■ And I.Consumerld = 0 & Customer ID & * And I. Agency = 10 & AgencyCode & 

■ & - 

■ And I. CaseNumber = < 0 & CaseNumber & 010 & _ 

n And I. Episode = n & Episode, cnn, adOpenDynamic , adLockOptimistic 

With rstlnterventions 

If rstlnterventions. BOP = False And rstlnterventions .EOF = False Then 
.MoveFirst 
. .While Not (.EOF) 

cbolnt erven tionCodes . Addlt em ! [Description] 

cboInterventionCodes . X teiriData (cbolnt erven tionCodes .Newln<3ex) = IndexNo 
. Int erven tionSeq( IndexNo) = l [InterventionSequence] 
InterventionDesc( IndexNo) = ! [Description] 
.MoveNext 

IndexNo = IndexNo + 1 
Wend 
End If 
End With 

CloseRst : 

rstlnterventions . Close 



• Load Payers from the database . 
IsNewPayer = False 

Set rstPayer = New ADODB . Recordset 
rstPayer .CursorLocation = adUseClient 

rstPayer. Open ° Select * From Payer Info Where Consumer ID = n & CustomerlD & ■ And Agency = 1 ° 
gencyCode & ° * And CaseNumber^ = ' n & _ 

CaseNumber & ■ 1 And Episode = " & Episode & D Order By PayerlD, PayerSequence, 
erLocation" . cnn, adOpenDynamic, adLockOptimistic 

If rst Payer. RecordCount » 0 Then 

IsNewPayer = True ' 

GoTo Authorizations 
End If , 

With rstPayer 

If Not C.BOF And .EOF) Then 
.MoveFirst 

PayerSequence = ! [PayerSequence] 
txtTotal = .RecordCount 

LoadDataToControls rstPayer, txtPayerContact , False 
LoadDataToControls rstPayer, txt Payer Phone, False 
LoadDataToControls rstPayer, txt IDWith Payer, False 
LoadDataToControls rstPayer, cboPayers, False 

If .RecordCount = 1 And .AbsolutePosition = 1 Then 

cmdPrevious Payer . Enabled = False 

cmdNext Payer. Enabled = False 

cmaNewPayer . Enabled = True 
End It 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

cmdPreviousPayer . Enabled = False 
cmdNextPayer . Enabled - True 
cmdNewPayer . Enabled « False. 
Elself .AbsolutePosition < .RecordCount Then 
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cmdPreviousPayer. Enabled = True 
cmdNext Payer . Enabled = True 
cmdNewPayer . Enabled = False 
Elself .RecordCount » .AbsolutePosition Then 
cmdPreviousPayer . Enabled = True 
cmdNextPayer. Enabled = False 
cmdNewPayer. Enabled = True 
End If t 
End If 
End If 
End With 

Display_Location 

' Load the location codes and descriptions for the payer that was saved 

• cboPayerLoca t ion . C lear 

•Set rstLocations = New ADODB . Recordset 
• rstLocations . CursorLocation = adUseClient 

•rstLocations. Open "Select Code, Description From PayerLocation" & _ n , B 

" Where PayerlD = 10 & cboPayers .ItemDatat cboPayers. Listlndex) & " ■ , cnn, a 

penDynamic , adLockOptimistic 

•With rstLocations 

• .Movejfirst 

• While Not ( .EOF) 

cboPayerLocat ion. Addl tern ! [Description! 

cboPayerLocation.ItexnData(cboPayerLocation.NewIndex) - i [Code] 

• .MoveNext 

• Wend 
'End With 

• rstLocations . Close 

•Set rstLocations = Nothing 

• Display the Location that was saved 

Set rstLocations = New ADODB . Recordset 
rstLocations. CursorLocation = adUseClient 

rstLocations. Open -Select PayerLocation. From Payerlnfo" & _ . „ , „ 

- Where Consumerld « 0 & CustomerlD & ■ And Agency « • " & AgencyCode & 
■ And CaseNumber = • * & CaseNumber & " 1 And Episode - ■ & Episode & _ 
- And PayerlD = • n & cboPayers .ItemData( cboPayers. List Index) & ■ • " , cnn, 

penDynamic, adLockOptimistic 

With rstLocations 
.MoveFirst 



Then 



While Not (.EOF) 

If Trim( ! [PayerLocation] & vbNullString) = 

cboPayerLocation. List Index = -1 
Else 

For j as 0 To cboPayerLocation. Li stCount r- 1 

If cboPayerLocation. I temData(j) - ! [PayerLocation] Then 
k = j 
Exit For 
End If 
Next 

cboPayerLocation. Listlndex = k 
End If 
. MoveNext 
Wend 
End With 

rstLocations . Close 

Set rstLocations - Nothing 



Authorizations : 
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• Authorizations Section 

• Load Authorizations from the database - 

IsNewAuth - True 

Set rstAuth = New ADODB. Recordset 

^^SSS^tS^'^SrS^tt,^ Consun.erlD = - * CustomerlD * - And Agency . - * , 

encyCode & 0 1 And CaseNumber = • ° & _ m 

CaseNumber & ° ■ And Episode = ° & Episode & _ , T i^^^chir 

-And PayerSequence = - & Payer Sequence, cnn/ adOpenDynamxc . adLockOptimistic 

If rstAuth.RecordCount = 0 Then 

cmdPreviousAuth. Enabled = False 

cmdNextAuth. Enabled = False 

cmdNewAuth. Enabled = False 

GoTo Finishup 
End If 

With rstAuth 

If Not (.BOF And .EOF) Then 

.MoveFirst , 
txtAuthorizationID = ! [ Author! zatxonID] 

txtAuthTotal =s .RecordCount - 
LoadDataToControls rstAuth, txtAuthStartDate, False 
LoadDataToControls rstAuth, txtAuthEndDate , False 
InterventionSequence - ! lint erven tionSequence] 
IsNewAuth = False 

Set rstStartDate = New ADODB . Recordset 
rstStartDate. Cur sorLocat ion » adUseClient 

rstStartDate. Open -Select StartDate From Interventions fc * MT1W - • » & AaencyCode & 

- Where Consumer Id .= u & Customer ID & n And Agency - & Agencyuuuc cc 

° & - -And CaseNumber = & CaseNumber & - And Episode = 0 & Episode &^ 

- tod InterventionSequence = ■ & InterventionSequence, cnn, adOpenDyr 

ic, adLockOptimistic 

With rstStartDate 

txtStartDate = ! [StartDate] 
End With 

rstStartDate. Close 

Set rstStartDate ■ Nothing 

x = 0 • Highlight the saved Intervention in the combo box 

For x = 0 To 99 m 

If InterventionSequence = InterventxonSeq(x) Then 

cboInterventionCodes . List index = x 
End If 
: Next 

■ Enable/Disable authorization navigation buttons accordingly 

If .RecordCount = 1 And .AbsolutePosition = 1 Then 

cmdPreviousAuth . Enabled = False 

cmdNextAuth . Enabled = False 

cmdNewAuth. Enabled = True 
End If 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1-Then 

cmdPreviousAuth. Enabled = False 

cmdNextAuth. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousAuth. Enabled - True 

cmdNextAuth. Enabled = True 
Elself .RecordCount » .AbsolutePositxon Then 

cmdPreviousAuth. Enabled = True 

cmdNextAuth . Enabled = False 

End If 
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End If 
End If 
End With 

Finishup : 
Exit Sub 

Err handler : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load 0 
End Sub 

Private Sub Fornu^loacU Cancel As Integer) 

Here: ' 

Set rstPayer = Nothing 

Set rstAuth - Nothing 

Unload Me 
End Sub 



Private Sub txtPayerPhone_Change ( ) 
If Lent txtPayerPhone) = 4 Then 

If Not IsNumeric (Mid (txtPayerPhone, 2, 3)) Then .„ww/*»i« 

MsgBox -Please enter a numeric number for the phone number!", vblnf ormation + vbOKOnly 

• Phone Number" 

txtPayerPhone = Mid ( txtPayerPhone , 1, 2) 
txtPayerPhone. SelStart = 2 
Else 

txtPayerPhone = txtPayerPhone & ")-" 
txtPayerPhone. SelStart = 7 
End If 

Elself Len( txtPayerPhone) = 9 Then 

If Not IsNumeric (Mid (txtPayerPhone, 7, 3)) Then „unvnniv 

MsgBox "Please enter a numeric number for the phone number!", vblnf ormation + vbOKOnly 

" Phone Number 0 

txtPayerPhone = Mid (txtPayerPhone, 1, 6) 
txtPayerPhone. SelStart = 7 
Else ' \ 

txtPayerPhone - txtPayerPhone & "~" 

txtPayerPhone . SelStart =11 , 
End If * 

Elself Len( txtPayerPhone) .= 14 Then 

If Not IsNumeric (Mid (txtPayerPhone, 11, 4)) Then „wwr*«i, 
MsgBox "Please enter a numeric number for the phone number!-, vblnf ormation + vbOKOnl} 

■ Phone Number" V; 

txtPayerPhone = Mid (txtPayerPhone, 1, 10) 
txtPayerPhone . SetFocus 
End If 

End If 
End Sub 

Private Sub txt Payer Phone__Got Focus ( ) 
If txtPayerPhone » ■ n Then 
txtPayerPhone = " ( " 
txtPayerPhone. SelStart =2 
End if 
End Sub 

Private Sub txtPayerPhone_KeyUp(KeyCode As Integer, Shift As Integer ) 
If txtPayerPhone = "" Or KeyCode = vbKeyBack Then 
txtPayerPhone = 0 ( n 
txtPayerPhone. SelStart * 2 • 
End If 
End Sub 



Private Sub txtPayerPhone_Los t Focus ( ) 

If txtPayerPhone = "( tt Then txtPayerPhone = 



End Sub 
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Option Explicit 

Dim AgencyName As* String 

Dim rsQA As New Recordset 

Private Sub cbovi si onChangedJLost Focus () 

If cboVisionChanged.Listlndex .= 1 Then 
cboActivity . SetFocus 

End If 
End Sub 

.Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdSave — Click ( ) 

SaveRecords 

End Sub 

Private Sub SaveRecords ( ) 
Dim tmpBufl As String 
Dim j As Integer 

Dim tmpParticipantNumber As String 
Dim tmpInterviewDate2 As Date 
Dim tmpStaf f As String 
Dim tmpPositive As String ■ 

Dim tmpDPositive As String ' Areas (0) 

Dim tmpPositiveDescription As String 
Dim tmpNewWays As String 

Dim tmpNewTechniques As String * Frequency 1 

pirn tmpNoTechniques As String 

Dim tmpCantDo As String 

Dim tmpAreas As String 

Dim tmpCDes crip t ion As String 

Dim tmpVisionChanged As String 

Dim tmpHowChanged As String 

Dim tmpMakeAppointment As String 

Dim tmpPost Activity As String 

Dim tmpPostSocial As String j 

Dim tmpPostFunctioning As String 

Dim tmpEndDate2 As Date 

On Error GoTo errSave 

If Trim(txtParticipantNumber) . » na Then 

MsgBox u You must enter a Participant Number!", vbOKOnly, "Save" 

txtPart icipantNumber . SetFocus 

Exit Sub 
Else 

tmpParticipantNumber = txt Part icipantNumber 
End If 

If Trim ( txt InterviewDate2) = ■ " Then 

MsgBox "You must enter an Interview Date!", vbOKOnly, "Save" 

txtInterviewDate2 . SetFocus 

Exit Sub 
Else 

tmpInterviewDate2 = txtInterviewDate2 
End If 

If cboStaff s/Listlndex = -1 Then 

MsgBox "You must enter a Staff ID!°, vbOKOnly, "Save" 

cboStaff s . SetFocus 

Exit Sub 
Else 

tmpStaff e cboStaff s.ItemData (cboStaff s .Listlndex) 
End If 

If cboPositive.Listlndex = -1 Then 

tmpPositive » 
Else 
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tmpPositive = cboPositive.ItemData(cboPositive.Iiistlndex) 
End If 

For j = 0 To lstAreas(O) .ListCount - 1 
If lstAreas(O) .Selected(j) Then 
tmpBufl = tmpBufl & "1° • 

Else 

tmpBufl = tmpBufl & "0° 
End If i 

Next 

tznpDPositive = tmpBufl 
tmpBufl = 

If Trim(tx.tPositiveDescription). o Then 

tmpPositiveDescription » ow 
Else 

tmpPositiveDescription = txtPositiveDescription 
End If 

If cboNewWays. List Index = -1 Then 

tmpNewWays = 0 ° 
Else • 

tmpNewWays = cboNewWays. ItemData (cboNewWays. Listlndex) 

End If 

If cboPrequencyl.I/i st Index = -i Then 

tmpNewTechniques = h a 
Else 

tmpNewTechniques = cboFrequencyl . ItemData (cboFrequencyl . Listlndex) 
End If 

If cboNoTechniques . List Index » -1 Then 

tmpNoTechniques = n » 
Else 

tmpNoTechniques » cboNoTechniques . ItemData (cboNoTechniques .Listlndex) 
End If 

If cboCantDo. Listlndex « -1 Then • 

tmpCantfco = oq 
Else . 

tmpCantDo = cboCantDo. ItemData (cboC an tDo. List Index) 
End If 

For j = 0 To lstAreas(l) .ListCount - 1 
If lstAreas(l) .Selected( j) Then 

tmpBufl - tmpBufl & "1" 
Else 

tmpBufl » tmpBufl & "0" 
End If 

Next 

tmpAreas = tmpBufl 
tmpBufl = 00 

If Trim(txtCDescription) = n " Then 

tmpCDescription = *° 
Else 

tmpCDescription = txtCDescription 
End If 

If cboVisionChanged. Listlndex = -1 Then 

tmpVisionChanged « 
Else 

tmpVisionChanged - cboVisionChanged. ItemData (cboVisionChanged. Listlndex) 
End If 

If cboHowChanged. Listlndex = -1 Then 

tmpHowChanged = ° " 
Else 
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tmpHowChanged = cboHowChanged . I temData( cboHowChanged. List Index) 
End If 

If cboMakeAppointment .List Index = -1 Then 

tmpMakeAppointment = ° ° 
Else 

tmpMakeAppointment = cboMakeAppointment . ItemData (cboMakeAppointment - List Index) 
End If 

If cboActivity.Listlndex = -1 Then 

tmpPostActivity = "° 
Else 

tmpPostActivity = cboActivity. ItemData (cboActivity.Listlndex) 
End If 

If cboFrequency 2. List Index = -1 Then 

tmpPostSocial = "* 
Else 

tmpPostSocial = cboFrequency2 , ItemData ( cboFrequency2 . Lis t Index) 
End If 

If cboEf feet . List Index = -1 Then 

tmpPost Functioning = u " 
Else 

1 tmpPostFunctioning = cboEf feet . ItemData (cboEf f ect - Listlndex) . 
End If 

If Trim(txtEndDate2) = "" Then 

tmpEndpate2 = °12:00i00 PM" 
Else 

tmpEndDate2 = txtEndDate2 
End If 

If (rsQA.BOF = False And rsQA.EOF = False) Then 

cnn. Execute "UPDATE QA Set ParticipantWumber » 1 * & tmpParticipantNumber & " ' , " & _ 
" InterviewDate2 = ■ " & tmpInterviewDate2 & " ■ , Interviewer2 = ' " & tmpStaf f & u 1 , " & _ 

■ Positive a ' » & tmpPositive & 0 ' , DPositive = ' " & tmpDPositive & " ' , " & _ 

• PositiveDescription » • 0 & tmpPositiveDescription & " 1 , NewWays = • w & tmpNewWays & 0 ■ , " & 
? NewTechnigues = 1 " & tmpNewTechniques & " ' , NoTechniques = 1 ■ & tmpNoTechniques & " • , ■ & _ 
0 CantDo » ' " & tmpCantoo & ■ • , CantDoThings = ' 0 & tmpAreas & "\, CDescription « 1 ■ & tmpCD 
ription & ■ ' , " & _ 

■ VisionChanged = ' " & tmpVisionChanged & n 1 , HowChanged « • ■ & tmpHowChanged & " 1 , w & _ 

■ MakeAppointment = ■ ■ & tmpMakeAppointment & " ' , PostActivity = *° & tmpPostActivity & 

" PostSocial = 1 " & tmpPostSocial & ■ • , Post Functioning = ' " & tmpPostFunctioning & n ■ , 0 & _ 
" EndDate2 = • " & tmpEndDate2 & a ' WHERE ConsumerlD = 0 & CustomerlD & n AND Agency = % * & A 
cyCode & ° 1 " & _ 

" AND Episode = ° & Episode & " AND CaseNumber - ' ° & CaseNumber & " • " 

MsgBox "Post Episode Survey successfully saved!", vbOKOnly, "Save" 

Exit Sub 
End If 
err Save: 

MsgBox Err -Description, vbCritical + vbOKOnly, "Save" 
End Sub . 

Private Sub FormJLoadO 

Dim tmpBuf As String 
Dim i' As Integer 

txtCaseNumber.Text = CaseNumber 
txt Episode. Text = Episode 

txtConsumerName.Text = FirstName & " 0 & LastName 
txtPhoneNumber = PhoneNo 



AgencyName = f rraMainMenu . txt AgencyName 

LoadControlsItems cboStaffs, False 
LoadControlsItems cboFrequencyl , False 
LoadControlsItems cboNoTechniques / False 
LoadControl si terns' cboHowChanged, False 
LoadControlsItems cboActivity, False 
LoadControl si terns cboFrequency2 , False 
LoadControlsItems cboEffect, False * 

lblPositlve; Caption * "Did the services you received from u & AgencyName • & ° make a positive d 
erence in your ability to do things?" 

lblNewWays. Caption = "When you received services from ° & AgencyName & ° were you shown new wa 
of doing things?" / 
lblFunctioning. Caption * "How much have " & AgencyName & n services affected your ability to f 
tion independently?" 

Set rsQA = New Recordset 

rsQA.Open "SELECT ParticipantNumber, InterviewDate2 , Interviewed , - & 

■ Positive, DPositive, PositiveDescription, NewWays, NewTechniques, " ' & _ 

■ NoTechniques, CantDo, CantDoThings , CDescription, VisionChanged, HowChanged 

& 

° MakeAppointment , PostActivity, PostSocial," & _ 
° Post.Functioning, EndDate2 p & _ 
° FROM QA" & _ 

B WHERE Consumer ID = " & CustomerlD & n AND Agency = • a & AgencyCode & a ' • & J. 
■ AND Episode = 0 & Episode & n AND CaseNumber = ' " & CaseNumber & 1,1,1 , cnn, adOpe 
namic, adLockOptimistic 

With rsQA 

If Not (.EOF And .BOF) Then 
.MoveFirst 

LoadDataToControls rsQA, txt ParticipantNumber, False 

1 For textboxes we don't use LoadDataToControls 

1 because VB cannot accept nulls as values 

• check for nulls or 12:00:00 PM in the database fields 

1 so we set the field to an empty string (»") or the field value 

If ! [InterviewDate2] = "12:00:00 PM" Or Trim< ! [InterviewDate2] & vbNullString = "") Then 

txtInterviewDate2 . = 0 n 
Else 

txtInterviewDate2 = ! [InterviewDate2J 
End If 

If '.[PositiveDescription] = "12:00:00 PM" Or Trim( ! [Posit iveDescrip tion] & vbNullString = 
Then 

txtPositiveDescription = " " 
Else 

txtPositiveDescription » ! [PositiveDescription] 
End If 

If ! [CDescription] = "12:00:00 PM" Or Trim( i [CDescription] & vbNullString « »•) Then 

txtCDescription = "" 
Else 

txtCDescription = ■ [CDescriptionl 
End If 



If ![EndDate2] = "12:00:00 PM" Or Trim( ! [EndDate2] •&. vbNullString = ■■) Then » 

txtEnODate2 = "" 
Else 

txtEndDate2 = J.[EndDate2] 
cmdSave. Enabled = False 
End If . 

tmpBuf = ! [Areas] .& vbNullString 



^^^f rmPost Episode 1 



ostEpisodel - 5 

For i = 1 To Len(tmpBuf ) 

If Mid(tmpBuf, i,- 1) = n l n Then 

IstAreasl. Selected (i - 1) = True 
Else 

IstAreasl. Selec ted (i - 1) = False 
End If 
Next- 



LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 
LoadDataToControls rsQA, 



cboStaffs, False 
cboBositive, False 
IstAreas, True 
cboFrequencyl , False 
cboNoTechni ques , Fa 1 s e 
cboVisionChahged, False 
cboHowChanged, False 
cboMakeAppointment , False 
cboActivity, False 
cboFrequency2 , False 



cboEffect, False 
Elself (.BOF And .EOF) Then 

MsgBox "Please complete the End of Episode Survey first" 
Unload Me 
End If 



VbpKOnly, "PostEpisode" 



End With 



End Sub 

Private Sub FonrL_Unload( Cancel As Integer) 

rsQA. Close 
End Sub 
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Option Explicit 

Private interventionCode (100) As String 
Private IDescription(lOO) As String 
Private rs As ADODB . Recordset 

Private Sub cmdClose_Click() 

Unload Me 
End Sub 

Private Sub cmdSave_Click ( ) 

SaveToDB 
End' Sub 

Private Sub SaveToDB {) 

Dim. tmplnt erven tion As String 
Dim tmpS tart Date As Date 
Dim tmpEndDate As Date 
Dim tmpStaf f As String 
Dim tmpStr As . String 
Dim CloseDate As, Date 
Dim Itemindex As Integer 
Dim rsl As ADODB . Recordset 

tmpEndDate = "12:00:00 PM n 

If cboInterventionCodes. List Index = -1 Then 

MsgBox "An Intervention is required to save this screen", vbOKOnly, "Missing Intervention 
cboInterventionCodes . SetFocus 
Exit Sub 

E1 Itemindex - cboInterventionCodes. List Index 1 Intervention selected in the combo box 

tmplntervention « InterventionCode (Itemindex) • The intervention code in the array 
End If ' that matches what the user selected 

Set rsl = New ADODB . Recordset 

tmoStr - ■ SELECT EndDate FROM Interventions WHERE ConsumerlD = ■ & CustomerlD & _ 
• - AND Agency = 1 ■ & AgencyC.ode & " ' ■ & " AND Episode = » & txtEpisode &. 

■ AND CaseNumber =* ' n & txtCaseNuraber & ° ■ AND Intervention™ = » ■ & tmplnterventic 

& n i n 

rsl. Open tmpStr, cnn, adOpenForwardOnly, adLockReadOnly 
If Not rsl. EOF Then 

If (rsl! [EndDate] =* "12:00:00 PM" ) Then bt 

MsgBox IDescript ion (Itemindex) & " is already opened to the consumer 0 , vbOKOnly, Interv* 

ion already opened" 

cboInterventionCodes . SetFocus 

GoTo Finishup 
End If 
v End If 

1 ^l£to^ S sS?2U%s retired to- save this screen", vbOKOnly, "Missing Start Date" 

txtStartDate . SetFocus . 

GoTo Finishup 
Else 

tmpStartDate = txtStartDate. Text 
End If 

If cboStaffs.Listlndex = -l.Then , . nw . Q . Qf . a « Name" 

MsgBox "A Staff Name is required to save this screen" , vbOKOnly, "Missing staff Name 
cboStaffs. SetFocus ~ * 

GoTo Finishup 

Else 

tmpStaff - cboStaffs. ItemData (cboStaffs.Listlndex) 
End If 



cnn. Execute "INSERT INTO Interventions n & _ . __ p nr in a te 

" (Consumerld, Agency, Episode, CaseNumber, InteryentionlD, StartDate, EndDate, 



c 
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fNaroe, EntryDate) VALUES <° & ^ • 

CustomerlD & ", to & AgencyCode & ■ • , ■ & txtEpisode & ■ , '." & txtCaseNumber & n 
• ■ & ttmplnt erven t ion & 0 ' , • ■ & tmpStartDate & ■ ■ , ' " & tmpEndDate & " ' , 1 w & tmpStaf f & ■ ■ , ■ 
°Now{))° 

cmdSave . Enabled = False 
cmdClose . SetFocus 

MsgBox "Successfully Saved ! " , vbOKOnly, "Intervention Referral" 

Finishup: 
. rsl. Close 

Set rsl =. Nothing 

Exit Sub 
End Sub 

Private Sub Forn\__Load ( ) 
Dim x As Integer 
x = 0 

• Get the consumer name and episode from the Interventions form 
txtLastName } = f rmlnterventionl . txtLastName 
txtFirstName = frmlnterventionl.txtFirstName 
txtCaseNumber = f rmlnterventionl . txtCaseNumber 
txtEpisode = f rmlnterventionl. txtEpisode 

IiOadControlsItems cboInterventionCodes, False 
LoadControl si terns cboStaffs, False 

Set rs = New ADODB. Recordset 

rs.Open "Select Code, Description From In t erven tionCodes" , cnn, adQpenForwardOnly, adLockRea 

ly 

rs.MoveFirst ' 
Do While Not rs.EOF 

InterventionCode(x) = rsl [Code] 

IDescription(x) = rs! [Description] 

rs.MoveNext 

x = x + 1 
Loop. 



rs. Close 
End Sub 



Option Explicit 
Private IsArrowKey As Integer 
Private IsNewCustoraer As Boolean 
Private rstReg As ADODB. Recordset 

Private Sub cboBiggestProblenuKeyUp( KeyCode As Integer, Shrift As Integer) 

If KeyCode = vbKeyBack Then 

cboBiggestProblem.Listlndex = -1 
End If 
End Sub 

Private Sub cboBiggestProblenuI-ostFocus () 

If Not CheckForShftTab Then 

If cboBiggest Problem. List Index <> 7 Then 
cboyesno(O) .SetFocus 

End if 
End If 
End Sub 

Private Sub cboCallerReason_KeyUp (KeyCode As Integer, Shift As Integer) , 

If KeyCode = vbKeyBack Then 

cboCallerRea son. I/is t Index - -1 
End If 
End Sub 

Private Sub cboCaseStatus_Click ( ) 
If IsArrowKey > 0 Then Exit Sub 

If cboCaseStatus .List Index <> 2 Then 

cboCaller Reason. Li st Index = -1 

cboStaf f St . SetFocus 
End If 
End Sub 

Private Sub cboCaseStatus_KeyDown (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode • 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode =* vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboCaseStatus_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboCaseStatus. Li st Index = -1 - 
End If 
End Sub 

Private Sub cboCaseStatus_"LostFocus ( ) 

If CheckForTab Then 

If cboCaseStatus*. Listlndex <> 2 Then cbostaffs .SetFocus 
End. If . 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboCorrespondence^JCeyUp (KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 
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cboCorrespondence. Lis tlndex = -1 

End If 
End Sub 

.Private Sub cboLanguages_KeyUp (KeyCode As Integer, Shift As Integer) 

.If KeyCode = vbKeyBack Then 

cboLanguages. Lis tlndex * -1 
End If 
End Sub 

Private Sub cboRef erral Sour ce_Key Up (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRef erralSource . List Index = -1 
End If • 
End Sub <* 

Private Sub cboRelationship_Click{ ) 

If cboRelationship.Listlndex <> 0 Then 

txtRegistration(8) = nn 

txtRegistration (9) » WM . 

txtRegistration (10) = »■ 

txtRegistration(ll) = " " 
End If 
End Sub 

Private Sub cboRe la tionship_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRelationship.Listlndex = -1 
End If 
End Sub 

Private Sub cboRelationship_Los t Focus ( ) 

If Not CheckForShftTab Then , 

If cboRelationship.Listlndex = 0 Then 

txtRegistration(8) = txtRegistration (3) 
txtRegistration (9) = txtRegistration (4) 
txtRegistration (10) = txtRegistration (5.) 
txtRegistration (11) = txtRegistration (6) 
End If 
End If 
End Sub 

Private Sub cboStaf fs_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboStaf fs. Lis tlndex = -1 
End' If - 
End Sub 

Private Sub cboYesNo_C lick (Index As Integer) 

If IsArrbwKey > 0 Then Exit Sub . 

If Index o 0 Then 

If cboyesno( Index) .Listlndex = 0 Then 

IstCrises . SetFocus 
pise 

IstUrgency . SetFocus 
End If 
Elself Index = 1 Then 

If cboyesno (Index) .Lis tlndex = 0 Then 

txtRegistration (13) * txtRegistration (12) 
txtRegistration (21) « txtRegistration (19) 
txtRegistration (0) = txtRegistration (20) 
• txtRegistration (23) = txtRegistration (22) 




s 
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Else 

txtRegistration(14) .SetFocus 
End If 
Elself Index = 3 Then 

If cboye,sno( Index) .Listlndex ■ 0 Then 

txtRegistration(7) = 00 

cboRelationship. Listlndex = 0 

cboRelationship . SetFocus 
End If 

End If . 
End Sub 

Private Sub cboYesNo_KeyDown (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode - vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode » vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboYesNo_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboyesno (Index) .List Index = -1 
End If 
End Sub 

Private Sub cboYesNo_LostFocus (Index As Integer) 

If Index = 0 Then 

If CheckForTab Then 

If cboyesno (Index) .Lis tlndex = 0 Then 

1 s t Crises . SetFocus 
Else 

Is tUrgency . SetFocus 
End If 
End If 
Elself Index = 1 Then 
If CheckForTab Then 

If cboyesno (Index) .Listlndex -. 0 Then 
N txtRegistration(13) = txtRegistration{12) 

txtRegistration(21) = txtRegistration(19) 
txtRegistration(O) txtRegistration(20) 
txtReferistration(23) = txtRegistration(22) 
Else 

txtRegistration(14) .SetFocus 
End If • 
End If 
Elself Index = 3 Then 
If CheckForTab Then 

If cboyesno (Index) .List index - 0 Then 
cboRelationship. Listindex = 0 
cboRelationship . SetFocus 
End If 
End If 
End If - 

If IsArrowKey > 0 Then IsArrowKey = 0 

End Sub , . • ' 

Private Sub cboyesno_JValidate (Index As Integer, Cancel. As Boolean) 



If Index ■ 0 Then 

If cboyesno (index) .Listindex - -1 Then 

MsgBox "Please had to select one of them! 



vblnformation + vbOKOnly, "In Crisis' 
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Cancel = True 
End If 
End If * ■ 

End Sub 

Private Sub cmdClose__Click() 
• f rmMaiiiMenu . Show 
Unload Me 
End Sub 

Pri.va.te Sub cmdInstructpgl_Click( ) 
Dim response As integer 

tabRegistration.Tab =0 

response = MsgBox ( "Actions : If in crisis a Supervisor will immediately intervene. & _ 

"If services rejected, a Contact Person will call within 24 hours to" & _ 

■ follow-up and offer assistance. If urgent, call within 48 liours.", vbOKOnly 

"Crisis") 

If response = vbOK Then tabRegistration.Tab = 1 
• End Sub 




Private Sub cmdlns true tpgl_Lost Focus ( ) 

If CheckForShf tTab Then 

tabRegistration.Tab = 0 

Is tUrgency . Set Focus 
End If 
End Sub 

Private Sub cmdNextPage_Click( } 

tabRegistration.Tab =1 
End Sub 

Private Sub cmdPrevious_C lick ( ) t 

tabRegistration.Tab =0 

End Sub j 

Private Sub cmdSave__Click( ) 
Dim colRe£ As New Collection 
Dim i "As Integer, j As Integer 
Dim tmpStr As .String 
•Dim rst As ADODB . Recordset . 
On Error GoTo errSave 

If Trim (txtRegistration (8) ) = Or Trim (txtRegistration (10) ) = "" Then 

MsgBox "Please enter both first name and last name", vblnformation + vbOKOnly, Registratioi 
Exit Sub 
•El self IsNewCustomer Then 

•Set rst = New ADODB. Recordset „ BB m m . t . . 

. • rst. Open "Select ConsumerlD, FinishDate From Registration Where VIFirstName « & Trxm(txi 

gistration(8) ) V ILastName = •» & Trira( txtRegi strati on (10) ) & " ,n , enn, adOpenForwardOnly , < 

ockReadOnly 

•If Not (rst.BOF And rst. EOF) Then 

•MsgBox "The name - & txtRegistration (8) & « ■ & txtRegistration(lO) & has registed al: 

dy!", _ 

vblnformation, "registration" 
■tabRegistration.Tab =0 
•Exit Sub 
'End If 

•Set rst* « Nothing 
End If 



colReg.Add cboyesno 
colReg.Add txtRegistration 
colReg.Add cboRelationship 
colReg.Add IstCrises 
colReg.Add Is tUrgency 



Legistrationl - 5 



6QM-397D8 -JOJL 



colReg.Add cboBiggestProblem 
colReg.Add cboReferralSource 
colReg.Add cboCorrespondence 
colReg.Add cboLanguages 
colReg.Add cboCaseStatus 
colReg.Add cboCallerReason 
colReg.Add cboStaffs 
colReg.Add txtAgency 

With rstReg 

If ( . EOF 4 And .BOF) Then .AddNew 

For i = 1 To colReg. Count , 
If i <= 2 Then 'for control collection case 

If TypeOf colReg (i) (0) Is TextBox Then 
For j = 0 To colReg (i) .Count - 1 

If colReg(i) (j) .Tag = "FinishDate" Then 
If Trim{ colReg (i) (j) ) - 00 Then 

. Fields. Item (colReg (i)'(j). Tag) = "12:00:00 PM» 
Else ' 

.Fields. I tem( colReg <i) { j) .Tag) - CDate (colReg (i) (j) ) 
End If 
Else 

.Fields. I tem( colReg ( i) (j) .Tag), = Trim (colReg (i) ( j ) ) 
End If 
Next 
Else 

For j = 0 To colReg(i) .Count - 1 

If colReg (i) (j) .Listlndex « -1 Then 
. Fields. I tem( colReg (i) (j).. Tag) = 
Else ; 

. Fields . Item ( colReg ( i ) (j) .Tag) = colReg(i) (j) .ItemData (colReg (i) (j) .Listlndex 
End If - 
Next 
End If 
Else 

If TypeOf colReg (i) Is IiistBox Then 

For j = 0 To colReg (i) .ListCount - 1 
If colReg (i) . Selected < j ) Then 

tmpStr = tmpStr & "l" 
Else ' 

tmpStr = tmpStr & °0 n / 
End If 
Next 

. Fields . I tem( colReg (i) -Tag) = tmpStr 

tmpStr = nn 
Elself TypeOf colReg (i) Is TextBox* Then 

.Fields. I tem( colReg (i) .Tag) = Trim(colReg(i) ) 1 
Else 

If colReg (i) .Listlndex = -1 Then 

. Fields. Item(colReg(i) .Tag) = °" 
Else 

. Fields. I tern ( colReg (i) .Tag) = colReg (i) .ItemData (colReg (i) .Listlndex) 
End If 
End If 
End If 
Next 
. Update 

End With • ' 
Me. Refresh 

MsgBox "Successfully saved the information!", vbOKOnly, "Save" 
Set colReg = Nothing 

Exit Sub • _ 

errSave : 

MsgBox Err .Description, vbCritical + vbOKOnly, "Save" 
End Sub. • 



Private Sub Formic tivate ( ) 
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On Error GoTo Errhandler 
txtAgency = AgencyCode 

1 lblRef erralSource . Caption = "p. How did you learn about the B & f rmSearchMenu . txt AgencyName . Te 
& "?" 

•If f rmSearch. txtTotalConsumers a «o° Then 

• txtRegistration ( 1 ) = f rmSearch . txtCaseNuiober 

1 txt Registration (8) = f rmSearch. txt Firs tName 

1 txtRegistration (10) = f rmSearch. txtLas tName 
•End If r 

LoadControlsItems cboStaffs, False 

Set rstReg = New ADODB. Recordset 
rstReg.CursorLocation = adUseClient 

rstReg, Open "Select * from Registration Where Consumer ID= u & CustomerlD, cnn, adOpenDynamic . ad 

ckOptimistic 

With rstReg 

If Not (.EOF And .BOF) Then 'Have record for this client and load it to f 

m 

.MoveFirst 

LoadpataToControls rstReg, cboyesno. True 

LoadDataToControls. rstReg, IstCrises, False 

LoadDataToControls rstReg, IstUrgency, False 

LoadDataToControls rstReg, cboRelationship, False 

LoadDataToControls rstReg, txtRegistration, True 

LoadDataToControls rstReg, txtAgency, False 

LoadDataToControls rstReg, cboBiggest Problem, False 

LoadDataToControls rstReg, cboRef erralSource, False 

LoadDataToControls rstReg, cboCorrespondence , False 

LoadDataToControls rstReg, cboLanguages , False 

LoadDataToControls rstReg, cboCaseStatus ) False 

LoadDataToControls rstReg, cboCallerReason, False 

LoadDataToControls rstReg, cboStaffs, False 
Else , 

IsNewCustomer = True \ 
End If* 
End With 

tabRegistration.Tab = 0 
txtAgency . SetFocus 
Exit Sub 

Errhandler : 

MsgBox Err .Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 

Private Sub Form_Unload (Cancel As Integer) 

'If rstReg. State = adStateOpen Then rstReg. Close 
FirstName = Trim( txtRegistration ( 8) ) 
LastName = Trim (txtRegistration (10) ) 
CaseNumber = Trim( txtRegistration (1) ) 
PhoneNo = Trim (txtRegistration (11) ) 

Address = Trim( txtRegistration (12 ) ) & - , » & Trim (txtRegistration (19) ) & ° , " & Trim( txtRe^isti 
ion(22)) & ■ u & Trim ( txtRegistration ( 20 ) ) 
If Trim (Address) = D , Then Address = 
Set rstReg = Nothing 

Set frmRegis trationl = Nothing i 
End Sub 

Private Sub lstCrises_KeyUp(KeyCode As Integer, Shift As Integer) 
Dim i As Integer 

If KeyCode = vbKeyBack Then 

If IstCrises - SelCount = 1 Then 

Is tCrises.Selec ted (IstCrises. List Index) a False 
Elself IstCrises. ListCoiint > 1 Then 
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For i - IstCrises.ListCount - 1 To 0 Step -1 
If lst£rises.Selected(i) Then 

lstCrises.Selected(i) = False 
End If 
Next 
End If 
End If 
End Sub 

Private Sub lstUrgency_.KeyUp(KeyCode As Integer, Shift As Integer). 
Dim i As Integer* 

If KeyCode « vbKeyBack Then 

If IstUrgency. SelCount - 1 Then 

Is tUrgency. Selected (IstUrgency .List Index) = False 
Elself IstUrgency. Lis tCount > 1 Then 

For i = IstUrgency. Lis tCount - 1 To 0 Step -1 
If IstUrgency. Selected (i) Then 

IstUrgency. Selected (i) = False 
End If 
Next 
End If 
End If 
End Sub • 

Private Sub 1 stUrgencyJLost Focus ( ) 

If CheckForTab Then 

tabRegistration.Tab = i 
End If 
End Sub 

Private Sub tabRegistration_Click(PreviqusTab As Integer) 

If tabRegistration.Tab = 1 Then 
cmdlnstructpgl . Set Focus 

frmRegistrationl. Caption = "Registration - Basic Information 2° 
cmdNextPage . Enabled - False 
cmdPrevious .Enabled = True 
Elself tabRegistration.Tab *= 0 Then 
1 txt Agency . Set Focus 

frmRegistrationl. Caption = "Registration - Basic Information 1" 

cmdPrevious . Enabled = False 

cmdNextPage . Enabled = True 
End If 
End Sub 



Private Sub txtRegistration_Change (Index As Integer) 



If Index = 17 Then 

If Len (txtRegistrat ion ( Index) ) = 3 Then 

If Not IsNumeric (Mid (txtRegistration (Index) , 1, 3)) Then 

MsgBox "Please enter numberic number for Social Security number! 0 , vblnf ormation + vbO 
nly, ■ Phone Number" » 

txtRegistration (Index) « ■ " 
txtRegistration ( Index) . SetFocus 
Else 

txtRegistration (Index) » txtRegistration (Index) & "-" 
txtRegistration ( Index) .SelStart = 5 
End If 

Elself Len (txtRegi strati on ( Index ) ) = 6 Then 

If Not IsNumeric (Mid (txtRegistrat ion (Index) , 5, 2)) Then 

MsgBox "Please enter numberic number for Social Security number! ", vblnf ormation + vbO 
nly, ■ Phone Number" 

txtRegistration (Index) = na 
txtRegistration (Index) .SetFocus 
Else 

" txtRegistration (Index) = txtRegistration (Index) & °- a 
txtRegistration (Index) .SelStart = 8 
End If 
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Elself Len ( txtRegistration ( Index) ) = 11 Then 

If Not IsNumeric (Mid (txtRegistration(Index) , 8, 4)) Then 

MsgBox "Please enter numberic number for Social Security number! 0 , vblnf ormation + vb< 
nly, " Phone Number" 

txtRegistration ( Index) = 
txtRegistration (Index) .SetPocus 
End If • 
End If 

Elself Index = 6 Or Index = 11 Or Index = 14 Or Index = 15 Then 
If Len (txtRegistration( Index) ) = 4 Then 

If Not IsNumeric (Mid(txtRegistration(Index) , 2, 3)) Then 

MsgBox "Please enter numberic number for phone number! ", vblnformation + vbOKOnly, ■ 1 
ne Number" 

txtRegistration (Index) = Mid (txtRegis tr at ion (Index) , 1, 2) 
txtRegistration (Index) .SelStart = 2 
Else 

txtRegistration (Index) = txtRegistration (Index) & ■)-■ 
txtRegistration (Index) .SelStart « 7 
End If 

Elself Len ( txtRegistration ( Index) ) = 9 Then 

If Not IsNumeric (Mid ( txtRegistration ( Index) , 7, 3)) Then 

MsgBox "Please enter numberic number for phone number!", vblnformation + vbOKOnly, " 1 
ne Number" 

txtRegistration (index) = Mid (txtRegistration (Index) , 1, 6) 
txtRegistration (Index) .SelStart = 7 
Else 

txtRegistration (Index) = txtRegistration (Index) & »-" 
txtRegistration (Index) .SelStart =11 
End If 

Elself Len ( txtRegistration ( Index) ) ■ 14 Then 

If Not IsNumeric (Mid ( txtRegistration ( Index) , 11, 3)) Then 

MsgBox "Please enter numberic number for phone number!", vblnformation + vbOKOnly, " 1 
ne Number" 

txtRegistration (Index) = Mid (txtRegis t rat ion (Index ) , 1, 10) 
txtRegistration (Index) .SetFocus 
End If 
End If 

aid If \ 
End Sub 

Private Sub txtRegist rat ion_Got Focus (Index As Integer) 

If Index = 6 Or Index = 11 Or Index = 14 Or Index = 15 Then 
If txtRegistration (Index) a BB Then 
txtRegistration (Index) ■■-(■. 
txtRegistration (Index) .SelStart * 2 
End If 
End »If 
End Sub 

Private Sub txtRegistration^KeyUp (Index As Integer, KeyCode As integer. Shift As Integer) 

If Index = 6 Or Index =» 11 Or Index = 14 Or Index » 15 Then 
If KeyCode = vbKeyBack Then 
txtRegistration (Index) = °( n 
txtRegistration (Index) .SelStart = 2 
End If 
Elself Index = 17 Then 

If KeyCode = vbKeyBack Then txtRegistration (Index) « 
End If 
End Sub 

Private Sub txt Regis tration_Lost Focus (Index As Integer) 

If Index = 6 Or Index = 11 Or Index = 14 Or Index = 15 Then 

If txtRegistration (index) = "(■ Then txtRegistration (index) = "" 
End If * 
End Sub 

Private Sub txt Regist rat ionl_Validate (Index As Integer, Cancel As Boolean) 



/ 
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Dim rst As ADODB. Recordset 

If Index = 1 Then , • • 

If txtRegistration{ Index) <> "" And IsNewCustomer Then 
Set rst = New ADODB . Recordset 

rst. Open "Select ConsumerlD From Registration Where CaseNumber = • 0 & - 

Trim (txtRegistration( Index) ) & " • ° , cnn, adOpenForwardOnly, adiockReadOnly 

If Not (rst. EOF And rst.BOF) Then 

MsgBox "The CaseNumber ■ & Tr im ( txtRegi strati on ( Index ) ) & 0 has been used, please sele< 

another one",'_ 

vblnformation + vbOKOnly, "Case Number 0 
txtRegistration( Index) = 00 
Cancel = True 
End If 

Set rst = Nothing 
End If 
Elself Index =2 Then 

If txtRegistration( Index) <> " " Then 

If Not IsDate ( txtRegi st rat ion ( Index) ) Then ' _ . ^ 

MsgBox "Please enter date in this field", vblnformation + vbOKOnly, "Registration Date 
Cancel = True 
End If 
End If 

Elself Index - 20 Or Index = 0 Then 

If txtRegistration( Index) <> "" Then 

If Not IsNumeric(txtRegistration(Index) ) Then . w«,,wi »t»^„4«4-^ 

MsgBox "Please enter numeric number in this field", vblnformation + vbOKOnly, Registr 

ion Date" 

Cancel = True . • 
End If 
End If 
End If 
End Sub 
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Option Explicit 

Private rstReport As ADODB. Recordset 
Private rstTemp As ADODB. Recordset 

Private Sub cmdActivityRepbrt_Click( ) 

If Not IsDate (Trim ( txtPeriodFrom) ) Then 

MsgBox "Please enter date for Reporting Period! ", vbln format ion, "Reporting Period 0 
txtPeriodFrom = on 
txtPeriodFrom. Set Focus 
Exit Sub t 

Elself Not IsDate(Trim(txtPeriodTo) ) Then 

MsgBox "Please enter date for Reporting Period!", vblnf ormation, "Reporting Peri" 
txtPeriodTo = 
txtPeriodTo. SetFocus 

Exit Sub / 
End If 

If Printers . Count = 0 Then 

MsgBox "Please add one printer to your computer! ", vbOKOnly + vblnf ormation, "Add Printer" 

Exit Sub 
End If 

cnn. Execute "Delete * from AgencyActivityReport 0 

Set rstReport = cnn. Opens enema (adSchemaTables, Array (Empty, Empty, "tmpTable", "Table")) 
If Not rstReport. EOF Then cnn. Execute "Drop table tmpTable" 

•For all Interventions 

If rstReport . State = adStateOpen Then rstReport .Close 

cnn. Execute "Select Distinct consumerlD Into tmpTable From Visits Where ( ServiceDate >=#"&_ 
Trim (txtPeriodFrom) & "# And ServiceDate <= #" & txtPeriodTo & "#) And (Duration Is Not Null 
nd duration <> 1 • ) ° 

cnn. Execute "Insert Into AgencyActivityReport (AllConsumers) Select Count (Consumer Id) From tmpTa 
e" . 

rstReport. Open "Select* * frpm AgencyActivityReport", cnn, adOpenDynamic , adLockOptimistic 
rstTemp.Open "Select Sum ( IIF ( (isdate (EpisodeClosedate) And EpisodeClo sedate <>. #12:00:00 PM#) , 
0)) AS EpisodeGlosed, " & _ 

"Sum(IIF(EpisodeOutcome =^ • 12 • , 1,0) ) As EpisodeOut cornel FROM Triage Where (EpisodeClosedat 
>= #" & Trim (txtPeriodFrom) & _ 

"# And EpisodeClosedate <= #" & Trim (txtPeriodTo) & "#)", cnn, adOpenForwardOnly, adLockRead 

ly 

rstReport ![ PeriodFrom] = Trim (txtPeriodFrom) 
rstReport! [PeriodTo] = Trim (txtPeriodTo) 

rstReport! [EpisodeClosed] = Ilf (IsNull (rstTemp! [EpisodeClosed] ) , 0, 1) 
rstReport! [EpisodeOut come 3 = Ilf (IsNull (rstTemp! [EpisodeOutcomel] ) , 0, 1) 

•rstReport! [SucessRate] ■ Ilf (rstTemp! [EpisodeClosed] = n 0 n , "0", Format ( (rstTemp ! [EpisodeOutcc 
1] / rstTemp! [EpisodeClosed] ) , "0.0%")) 
If rstReport! [EpisodeClosed] « "0" Then 

rstReport! [SucessRate] = °0" 
Else 

rstReport! [SucessRate] « Format ( (rstReport ! [EpisodeOutcbme] / rstReport! [EpisodeClosed] ) , "0 
%") • 
End If 

rstReport .Update 
rstTemp . Close 

cnn. Execute "Drop Table tmpTable" 

Call InterventionActivity( "SocialConsumers" , "SocialClosed" , 0 SocialOutcome" , "SocialSucessRate 
"010") 

•Call InterventionActivity("PSConsumers n , "PSClosed", "PSOutcome", "PSSucessRate" , "011") 
Call lnterventionActivity("lliConsumers", "ILClosed", "iLOutcome", "ILSucessRate" , "013") 
Call IntervehtionActivity(°OMConsumers", "OMClosed" , "OMOutcome", "OMSucessRate" , "014") 

•Call InterventionActivity("CSConsumers" , "CSClosed" , "CSOutcome" , "CSSucessRate" , "031") 
tall InterventionActivity("LVConsumers", "LVClosed" , "LVOutcome" , "LVSucessRate" , "041") 

•Call InterventionActivity("IDConsumers", "IDClosed", "iDOutcome", "IDSucessRate" , "045") 

•Call InterventionActivity("DMConsumers", -DMClosed", "DMOutcome" , "DMSucessRate" , "047") 
Call InterventionActivity("EmploymentConsumers", "EmploymentClosed" , "EmploymentOutcome" , "Emp] 
ment SucessRate", "050") 

•Call InterventionActivity("ASConsumers", "ASClosed" , "ASOutcome", "ASSucessRate" , "056") 
•Call InterventionActivity("MUConsumers", "MUClosed", "MUOutcome", "MUSucessRate" , "121") 
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•Call InterventionActivity ("RSConsumers", "RSClosed 0 , "RSOutcome 0 , "RSSucessRate" , "141") - 
Call InterventionActivity ( "ComputerConsumers" , "ComputerClosed 0 , °ComputerOutcome n , "ComputerSuc 
ssRate"-, "160") 

Set rptAgencyActivity.DataSource = rstReport 

rptAgencyActivity . PrintReport 

End Sub / 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub InterventionActivity (strConsumer As String, strClosed As String, strOutcome As Strii 
, strSucessRate As String, tmpID As String) 

cnn Execute "Select Distinct consumerlD Into tmpTable From Visits Where ( ServiceDate >=#"&_ 
Trim(txtPeriodFrom) & "# And ServiceDate <= #" & txtPeriodTo & "#) And InterventionID = ,n & 

rstTemp.Open "Select Count (Consumerld) From tmpTable", cnn, adppenForwardOnly, adLockReadOnly 
rstReport. Fields (strConsumer) = rstTemp . Fields ( 0 ) ' 
rstReport. Update 
rstTemp - Close 

rstTemp.Open "Select Sum(IIF ( (isdate (EndDate) And EndDate <> #12:00:00' PM#) , 1, 0)) AS Closed, 
St 

Sum(IIF(lnterventionOutcome = '12-, 1,0) ) AS Outcome FROM .Interventions Where ( 'EndDate > 

#" & * 

Trim(txtPeriodFrom) & "# Arid EndDate <= #" & txtPeriodTo & "#) And InterventionID = ■» & tmp 
& "'", cnn, adOpenForwardOnly, adLockReadOnly 
rstReport. Fields (strClosed) = Ilf (IsNull (rstTemp! [Closed] ) , 0, 1) 
' rstReport. Fields (strOutcome) =* Ilf (IsNull (rstTemp! [Outcome] ) , 0, 1) 
If rstReport . Fields (strClosed) = "0° Then 
rstReport. Fields (strSucessRate). . = "0,0%" 

El3 rstReport. Fields (strSucessRate) = Format ( (rstReport .Fields (strOutcome) / rstReport . Fields ( st 
losed)), "0.0%") 
End If 

rstReport .Update 
rstTemp . Close 

cnn. Execute "Drop Table tmpTable" 
End Sub 

Private Sub Form_IiOad() 

Set rstTemp = New ADODB. Recordset 
rstTemp. Cur sorLocat ion = adUseClient 

Set rstReport - New ADODB . Recordset 
rstReport .Curs orLocat ion = adUseClient 
End Sub 

Private Sub FormJJnload (Cancel As Integer) 

If rstReport. State = adStateOperi Then rstReport .Close 

Set rstReport = Nothing 

Set rstTemp = Nothing 

Set 'frmReportMenu = Nothing 

End Sub 



earch 1 
Option Explicit 

Private rstSearch As ADODB. Recordset 
Private Sub cmdAdd__Click() 

Customer ID = 0 ' for existing record, 

f rmRegistrationl . Show 
End Sub 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdMainMenu_Click( ) 
f nnMa inMenu . Show ' vbModal 
End Sub 



the Customer ID had to be larger than 1 




Private Sub cmdNext_Click { ) 

With ret Search' 
. Mo veNext 

If . Absolut ePos it ion = .RecordCount Then cmdNext . Enabled = False 

txtCounter = . AbsolutePosition x 

txtCaseNumber = ! [CaseNumber] 

txtLastName = ! [VILastName] 

txtFirstName =' I [VTFirstName] 

CaseNumber = ! [CaseNumber] 

Customer ID = ! [consumer id] 

AgencyCode = ! [Agency-] 

FirstName = ! [VIFirstName] 

LastName = ! [VILastName] 

PhoneNo = ! [VI Phone] 

Address = ! [addressl] & ■ , B & ! [Cityl] & ■ , ■ & ! [Statel] & ° 0 & I [Zipl] 

If Trim (Address) = a , , n Then Address = D ° 

cmdPrevious . Enabled = True 

txtFirstName . SetFocus 
End With 
End Sub 

Private Sub cmdPrevious_ClicK( ) 

With rst Search 
. .MovePrevious 
If .AbsolutePosition = 1 Then cmdPrevious . Enabled = False 
txtCounter » .AbsolutePosition 
txtCaseNumber = ! [CaseNumber] 
txtLastName = ! [VIliastName] 
txtFirstName = ! [VIFirstName] 
CaseNumber = ! [CaseNumber] 
Customer ID = ! [consumer id] 
AgencyCode = » [Agency] 
FirstName = i [VIFirstName] 
LastName = ! [VILastName] 
PhoneNo = ! [VI Phone] 

Address = ! [addressl] & ■ , - & ! [Cityl] & «, » & ! [Statel] & u n & ! [Zipl] 

If Trim(Address) = " , , n Then Address = " a 

cmdNext . Enabled = True 

txtFirstName . SetFocus 
End With 
End Sub c 

Private Sub Form_Activate O 
Dim tmpStr As String 

If rstSearch. State = adStateOpen Then rstSearch. Close 

rst Search. Open SQLString, cnn, adQpenForwardOnly, adLockReadOnly 

Set SearchGrid.DataSource = rstSearch 

With rstSearch 

If Not { .BOF And . EOF) Then • 
.MoveFirst 
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txtTotalConsumers = -RecordCount 
txtCounter = .AbsolutePosition 
txtCaseNumber = ! [CaseNumber] 
txtLastName = ! [VILastName] 
txtFirstName = ! [VlFirstName] 
CaseNumber = ! [CaseNumber J 
Customer ID = ! [consumerid] 
AgencyCode' = ! (Agency] 
FirstName = ! [VlFirstName] 
LastName' = I [VILastName] 
PhoneNo = ! [VIPhone] 

Address = ! [addressl] & n , ■ & '[Cityl]. & », f & ! [Statel] & «. " & ![Zipl]. 
txtCaseNumber = CaseNumber 
txtLastName = LastName 
txtFirstName ?= FirstName «. 
If Trim (Address) = " , , ■ Then Address = ■» 
If .RecordCount > 1 Then cmdNext - Enabled - True 
cmdMainMenu. Enabled = True 
Else 

txtTotalConsumers = 0 
txtCounter = 0 
txtCaseNumber = M ■ 
txtLastName = °» 
txtFirstName = on 
cmdMainMenu . Enabled = False 
cmdNext . Enabled = False 
cmdPrevious .Enabled = False 
End If 
End With 

txtTotalConsumers . SetFocus 
End Sub 

Private Sub Form_Load() 

Set rstSearch = New ADODB. Recordset 
rstSearch. CursorLocat ion = adUseClient 

End Sub r 

• i 

Private Sub Form_Unload( Cancel As Integer) 
If Forms. Count = 1 Then 

If cnn. State = adStateOpen Then cnn. Close 

Set cnn = Nothing ... 
End If 

If rstSearch. State = adStateOpen Then rstSearch ".Close 
Set rstSearch = Nothing 
Set frmSearch .=» Nothing 
End Sub 

Private Sub SearchGrid_SelChange (Cancel As Integer) 

If SearchGrid.SelBookmarks. Count = 0 Then Exit Sub 
rstSearch. AbsolutePosition = SearchGrid . SelBookmarks ( 0 ) 

With rstSearch 

If Not' (.BOF And .EOF) Then 

txtCounter .AbsolutePosition 
txtCaseNumber = ! [CaseNumber] 
txtLastName = l (VILastName] 
txtFirstName = ! [VlFirstName] 
CaseNumber = ! [CaseNumber] 
CustomerlD = ! [consumerid] 
AgencyCode = I [Agency] 
FirstName = ! [VlFirstName] 
LastName « ! [VILastName] 

Address = ! [addressl] & » , " & ! [Cityl] & «, ■ & J [Statel] & n ■ & ! [Zipl] 
If Trim(Address) = " , , ■ Then Address = 00 

If .RecordCount > 1 Then 



f rmSearch 



If .AbsolutePosition = 1 Then 

cmdPrevious . Enabled = False 

cmdNext . Enabled = True 
ElseXf . Absolut ePosit ion < .RecordCount Then 

cmdPrevious . Enabled = True 

cmdNext . Enabled = True* 
ElseXf .RecordCount - . AbsolutePosition Then 

cmdPrevious . Enabled = True 

cmdNext .Enabled = False 
. End If 
End If 



txtCdunter . SetFocus 



End If 
End With 
End Sub 
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Option Explicit 

Private Sub cboln t erven t ioncode s_KeyUp {KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboInterventionCodes. Lis tlndex = -1 
End If , 
End Sub 

Private Sub cboStaff s_KeyUp ( KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboStaffs. List Index = -1 
End If 
End Sub 

Private Sub cmdClear_Click( ) 

cboInfcerventionCodes.iiistlndex = -1 
cboStaff s.Listlndex = -1 
txtLastName. Text = n ° 
txtFirstName.Text = 

txtCaseNumber.Text = ' 1 
End Sub 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdReport_Click{ ) 

f rmReportMenu . Show vbModal 
End 'Sub 

Private Sub cmdSearch_Click ( ) 

LastName = Trim (txtLastName) ' 
EirstName = Trim(txtFirstName) 
CaseNumber = Trim(txtCaseNumber) 

txtLastName » Replace (txtLastName, ■ ' ■ , ■ 9 • ° ) 

If cboInterventionCodes. Listlndex <> -1 Then 1 Select by Intervention and Staff (if exists) 

SQLString = ° SELECT DISTINCT R.VILastName, R. VIFirstName, R. CaseNumber, R.ConsumerlD, R.VIPhc 
e, ■ & _ 

0 I. Interventions, R.Addressl, R.Cityl, R.Statel, R.Zipl, R. Agency FROM Registry 
ion R, Interventions I" & _ 

0 WHERE R.ConsumerlD « I . Consumer ID AND I . Interventions = (Select Code from Int€ 
ventionCodes" & _ 

n Where Description = 1 ■ & cbo In t erven tionCodes .Text & « 1 ) AND ( I . EndDate . Is Null 
OR I. EndDate = #12:00:00 PM#) ■ & _ 

" AND Rl Agency = ' ° & txtAgencyCode & * 1 " 

If cboStaff s.Listlndex <> -1 Then 

SQLString = SQLString & ■ And I. Staff Name « »■ & cboStaff s . ItemData (cboStaff s .List Index) & 

t o 

End If 
End If 

If cboInterventionCodes. List Index = -1 And cboStaff s.Listlndex <> -1 Then • Select by staff, nc 
intervention 

SQLString = ° SELECT DISTINCT R.VILastName, R . VTFir stName , R . CaseNumber , R.ConsumerlD, R.VIPhc 
e, ■ & _ 

w I.Interventionlp, R.Addressl, R.Cityl, R.Statel, R.Zipl, R. Agency, I^StaffName 
ROM Registration as R, Interventions I n & 

0 WHERE R. Consumer Id = I. Consumer ID AND R. Agency = • " & txtAgencyCode & * 1 M & _ 
- AND (I. EndDate Is Null OR I. EndDate = #12:00:00 PM#) AND I.StaffName = ' ° & _ 
cboStaffs. ItemData( cboStaff s.Listlndex) & n,n 

End If 

If cboStaff s.Listlndex = -1 And cboInterventionCodes .List Index = -1 Then ' No staff, no interve 
tion 

SQLString = B SELECT DISTINCT R.VILastName, R. VIFirstName, R. CaseNumber, R.ConsumerlD, R.Addre 
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sl '° * - " -R.cityl, R.Statel, R.Zipl, R.VTPhone. R . Agency FROM Registration R WHERE R.Agei 

y = 1 " & txtAgencyCode & " 1 ■ 
End If 

If Trim (txtLas tName. Text) <> ° ° Then 

SQLString = SQLString & ° AND R. VTLas tName Like ,n & Trim ( txtLas tName) & % 

End If 

If Trim (txt Firs tName. Text) <> Then • 

SQLString = SQLString & 11 AND R. VIFirstName Like ' °& Trim( txt Fxrs tName) & % 
End If 

If Trim ( txt CaseNumber. Text) <> ■ ■ Then 

SQLString = SQLString .& ".AND R. CaseNumber = & Trim( txtCaseNumber) & 
End If 

. SQLString = SQLString & " Order By R.VILastName" 
frmSearch.Show 'vbModal 
End Sub 

Private Sub Form^Activate ( ) 

cboInterventionCodes . Listlndex = -1 

cboStaff s.Listindex = -1 

txt Las tName. Text = "° 

txtFirstName.Text = " " 

txtCaseNumber .Text = 0 ■ 

txtFirstName. SetFocus 
End Sub 

Private Sub Form_Load() 

LoadControlsItems cboStaff s, False 
LoadControlsItems cboInterventionCodes, False 

AgencyCode = txtAgencyCode 
End Sub ^ 

Private Sub Form_Unload (Cancel As Integer) 
If Forms. Count = 1 Then 

If ' cnn. State = adStateOpen Then cnn. Close 

Set cnn = Nothing 
End If 

Set frmSearchMenu = Nothing 
End Sub 
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Option Explicit 
Private IsArrowKey As Integer 
Private IsHousinglssues As Boolean 
Private rst As ADODB. Recordset 
Private GoalPosition As Integer 
Private Trigger Position As Integer 
Private rstSocial As ADODB. Recordset 
Public IsNewRecord As Boolean . 
Private I sGoalsC licked As Boolean 
Public IsFileDateChecked As Boolean 
Private I sVisuallnf ©Clicked As Boolean 

Private Sub *cboAgree__Click( Index As Integer) 
Dim i As Integer 

If IsArrowKey > 0 Then Exit Sub 

Call cboAgree_Validate ( Index, False) 

If Index = 3 Or Index = 4 Or Index = 9 Or Index = 11 Or Index 
Or Index « 22 Or Index = 25 Or Index =27 Then 
For i = GoalPosition + 1 To chkRecommendation. Count - 1 
If chkRecommendation (i) ^ Value = 1 Then 
GoalPosition = i 
■ If i > 4 Then tabSocial . Tab « 8 
chkRecommendation ( i ) . SetFocus 
Exit Sub 
End. If 
Next 



= 15 Or Index = 17 Or Index = 2( 



tabSocial . Tab = 8 

Call CountScore 

Call CountGoals 

txtsocial (11) .SetFocus 
End If 
End Sub 

Private Sub cboAgree_KeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDovm Then 

IsArrowKey = KeyCode * 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 

End Sub ' ' 

Private Sub cboAgreeJKeyUp { Index As Integer, KeyCode As Integer. Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboAgree ( Index) .Listlndex = 1 
End If 
End . Sub 

Private Sub cboAgree_Lost;Focus (Index As Integer) 
Dim i As Integer 



If CheckForTab Then 

Call cboAgree_Validate ( Index, False) 

If Index = 3 Or Index = 4 Or Index = 9 Or Index 



11 Or Index = 15 Or Index = 17 Or Index = 



Or Index = 22 Or Index = 25 Or Index = 27 Then 
For i = GoalPosition + 1 To chkRecommendation . Count - 1 
If chkRecommendation <i) .Value = 1 Then 

GoalPosition = i 

If i > 4 Then tabSocial . Tab = 8 

chkRecommendation (i) .SetFocus 

Exit Sub 
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Next 

tabSocial .Tab = 8 
Call CountScore 
Call CountGoals 
txtsocial(ll) .SetFocus 
fend If 
End If 

If IsArrowKey > 0 Then. IsArrowKey = 0 
End Sub 

Private Sub cboAgree_ Validate ( Index As Integer, Cancel As Boolean) 

If Index = 0 Or Index = 1 Or Index ■ 2 Or Index = 3 Then 

If cboRecommend<0) -Text <> "Yes" Then cboAgree (Index) .Lis tlndex = -1 
Elself Index = 4 Then 

If cboRecornmend(l) .Text <> "Yes" Then cboAgree (Index) J Lis tlndex = -1 
Elself Index = 5 Or Index = 6 Or Index = 7 Or Index = 8 Or Index. = B Then 

If cboRecorranend(2) .Text <> "Yes" Then cboAgree (Index) .Lis tlndex « -1 
Elself Index = 10 Or Index « 11 Then 

If cboRecommend(3) .Text <> "Yes" Then cboAgree (Index) .Lis tlndex = -1 , 
Elself Index = 12 Or Index « 13 Or Index = 14 Or Index = 15 Then 

If cboRecornmend(4) .Text <> "Yes" Then cboAgree (Index) .Lis tlndex = -1 
Elself Index = 16 Or Index « 17 Then 

If cboRecommend{5) .Text <> "Yes" Then cboAgree (Index) .Lis tlndex = -1 
Elself Index = 18 Or Index = 19 Or Index = 20 Then 

If cbpRecoinmend(6) .Text <> "Yes" Then cboAgree ( Index) .Listmdex = -1 
Elself Index - 21 Or Index = 22 Then 

If cboRecommend(7) .Text <> "Yes" Then cboAgree (Index) .Listmdex = -1 
Elself Index = 23 Or Index = 24 Or Index = 25 Then 

If cboRecoinmend(8) .Text <> "Yes" Then cboAgree (Index) .Listmdex = -1 
Elself Index = 26 Or Index = 27 Then 

If cboRecommend(9) .Text <> "Yes" Then cboAgree (Index) .Listlndex * = -1 
Elself Index = 28 Then 

If cboRecommend(lO) .Text <>. "Yes" Then cboAgree (Index) .Lis tlndex = -1 
End If j 
End Sub 

Private Sub cboDif ficulty_Click( Index As Integer) 

If IsArrowKey > 0 Then Exit Sub 

If Index = 1 Or Index = 2 Then 

If cboDif f iculty ( Index) .Listmdex = 0 Or cboDif f iculty ( Index) .Lis tlndex ■ 1 Then chkRecornnw 
tion(0) .Value =1 

Elself Index = 3 Or Index = 4 Then 

If cboDif f iculty (Index) .Listlndex = 0 Or cboDiff iculty (Index) .Lis tlndex =» 1 Then . ' 

'chkRecommendation(l) .Value = 1 
chkRecommendation(2) .Value » i 
End If 
Elself Index = 5 Then 

If cboDiff iculty (Index) .Listmdex = 0 Or cboDif f iculty (Index) .Listlndex = 1 Then chkRecontme 
tion(3) .Value = 1 
Elself Index = 6 Then 

. If cboDif f iculty (Index) .Listlndex = 0 Or' cboDiff iculty (Index) .Listlndex » 1 Then chkRecomm* 
tion(4) .Value =1 
Elself Index = 7 Then 

If cboDif ficulty( Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listmdex = 1 Then chkRecomme 
tion(5) .Value =1 
Elself Index = 8 Then 

If cboDif f iculty (Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listlndex =1 Or cboDif ficult 
ndex) .Listlndex = 2 Then 

chkRecoramendation(8) .Value ~ 1 
Else 

txtMarrat ive ( 6 ) . SetFocus 
End If 

Elself Index = 9 Or Index = 10 Or Index = 11 Then 

If cboDif ficulty(Index) .Listlndex = 0 Or cboDiff iculty (Index) .Listmdex = 1 Then chkRecc 
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End If 
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ndation{6) .Value =1 
End If 
End Sub 

Private Sub cboDif ficultyJKeyDown( Index As integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
El self KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode « vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLef t Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboDif ficulty_KeyUp( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode - vbKeyBack Then 

cboDifficulty (Index) .Listlndex = 1 
End If 
End Sub 

Private Sub cboDif ficulty_Lost Focus (Index As Integer) 

If CheckForTab Then 

If Index = 1 Or Index = 2 Then- 

If cboDifficulty (Index) .Listlndex - 0 Or cboDif f iculty ( Index) .List Index « 1 Then chkRecoi 
ndation(O) .Value = 1 

Elself Index = 3 Or Index « 4 Then 

If cboDifficulty (Index) .Listlndex = 0 Or cboDifficulty (Index) .List Index « 1 Then 
chkRecommendation (1) .Value = 1 
chkRecommendation ( 2 ) .Value = 1 
End If 
Elself Index = 5 Then ' 

If cboDifficulty (index) .Listlndex = 0 Or cboDifficulty (Index) .Listlndex = 1 Then chkRecoi 
ndation(3) .Value « 1 

Elself Index =.6 Then 

If cboDifficulty (Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listlndex = 1 Then chkRecoi 
ndation(4) .Value = 1 

Elself Index = 7 Then 

If cboDifficulty (Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listlndex - 1 Then chkRecoi 
ndation(5) .Value =1 

Elself Index = 8 Then i 

If cboDif f iculty (Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listlndex = 1 Or cboDiffict 
y( Index) .Listlndex = 2 Then 

chkRecommendation (8) .Value = 1 
Else 

txtNarrat ive ( 6 ) . Set Focus 
End If 

Elself Index =* 9 Or Index = 10 Or Index - 11 Then 

If cboDifficulty (Index) .Listlndex = 0 Or cboDif f iculty (Index) .Listlndex = 1 Then chkRecou 
ndation(6) .Value a l 

End If 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 • 
End Sub 

Private Sub cboInformation_Click (Index As Integer) 
If IsArrowKey > 0 Then Exit Sub 

If index = 4 Then 

If cbolnformation (Index) .Listlndex <> 4 Then cboYesNo(6) .SetFocus 
Elself Index = 6 Then 

If cbolnformation (Index) .Listlndex <> 3 Then cbolnformation (7) .SetFocus 
Elself Index = 9 Then 

If cbolnformation (Index) .Listlndex <> 4 Then* txtNarrative (4) .SetFocus 
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El self Index = 10 Then 

If cbolnf ormation* Index). Lis tlndex <> 4 Then txtNarrative (5) . SetFocus 

ElS l"cS?n1oLatiOTa5) .Listlndex = 0 Or cbolnfonoaticin( 15) .Lis tlndex = 1 Or cboInformation<15> 

Listlndex « 2 Then 

chkRecoramendationO) -Value = 1 
End If 
Elself Index = 17 Then 

tabSocial.Tab = 9 
End if » 
End Sub 

Private Sub cbolnf ormation_KeyDown ( Index As .Integer, KeyQode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey ='■ KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cbolnf ormat ion_KeyUp (Index As Integer. . KeyCode As Integer, Shift As Integer) 

If KeyCode - vbKeyBack Then 

cbolnf ormat ion ( Index) .Listlndex « -1 
End 'If 
End Sub 

Private Sub cbolnf ormation_JLostFocus (Index As Integer) 

If CheckForTab Then 
If Index = 4 Then 

If cbolnf ormation (Index) .Listlndex <> 4 Then cboYesNo (6) .SetFocus 

ElS If f cboIn^ori4tion^Index) .Listlndex <> 3 Then cbolnf ormat ion (7) .SetFocus 

, E1S jf f C boInf brmationUndex) .Listlndex <> 4 Then txtNarrative (4) ..SetFocus 

Elself Index = 10 Then te , x . t „ 

If cbolnf ormation ( Index) .Listlndex <> 4 Then txtNar rat xve (5) . SetFocus 

ElS I E ^bo?nforma?ioS - 0 Or cbolnf ormat ion (15 ). Listlndex = 1 Or cbolnf ormat ion 

5) .Listlndex = 2 Then 

chkRecommendation(9) .Value = 1 
End If 
Elself Index = 17 Then 
If CheckForTab Then 

tabSocial.Tab ="9 
End If 
End If 

End If - 

If IsArrowKey > 0 Then IsArrowKey =0 

End Sub % 

Private Sub cboRatingjC lick (Index As Integer) 
Dim i As Integer 

If IsArrowKey > 0 Then Exit Sub 

' If Trigger Position >= 10 Then 
tabSocial.Tab « 7 
Else 

For i « reiggerPosition + 1 To chkTrigger . Count - 1 
If chkTrigger (i) .Value a 1 Then 
TriggerPosition = i 
Call GetAssessmentTab 



tabSocial.Tab - 1 
End If 
End Sub 

Private Sub cboRatingJKeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
El self KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode - vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboRating_Lost Focus (Index As Integer) 
Dim i As Integer 

If CheckForTab Then 

If TriggerPosition >= 10 Then 

tabSocial.Tab =7 
Else 

For i = TriggerPosition + 1 To chkTrigger . Count - 1 
If chkTrigger (i) .Value = 1 Then' 
TriggerPosition =* i 
Call GetAssessmentTab 
Exit Sub 
End If 
Next 

tabSocial.Tab = 7 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboRecommend_Click ( Index As Integer) 
Dim i As Integer 

If IsArrowKey > 0 Then Exit Sub 

If cboRecommend( Index) -List Index = 1 Then 

For i = GoalPosition + 1 To chkRecommendat ion. Count - 1 
If chkRecommendation(i) .Value = 1 Then 
GoalPosition » i 

If i > 4 Then tabSocial.Tab = 8 
chkRecommendat ion ( i ) . SetFocus 
Exit Sub 

tabSocial.Tab « 8 
Call CountScore 
Call CountGoals 
End If 
Next 
End If 
End Sub 

Private Sub cboRecommend_KeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown. Then 

IsArrowKey = KeyCode 
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Exit Sub 
End If * 
Next 
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Elself KeyCode .=* vbKeyRight Then 

isArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboRecommendLKeyUp { Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboRecommend (Index) .Listlndex =1 
End If 
End Sub 

Private Sub cboRecorranencLLostFocus (Index As Integer) 
Dim i As Integer 

If CheckForTab. Then 

If cboRecommend (Index) .List Index = 1 Then 

For i = GoalPosition + 1 To chkRecommendat ion . Count - 1 
If chkRecommendation(i) .Value = 1 Then 
GoalPosition = i 
If i > 4 Then tabSocial .Tab = 8 
chkRecommendat ion ( i ) . SetFocus 
If IsArrowKey > 0 Then IsArrowKey » 0* 
Exit Sub 



tabSocial. Tab = 8 
Call CountScore 
.Call CountGoals 
End If 
Next 
End If' 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboRecommendL.Valkda.te ( Index As Integer, Cancel As Boolean) 

If chkRecommendation ( Index) .Value <> 1 Then cboRecommend (Index) .List Index = -1 

End" Sub 

Private Sub cboYesNo_Click ( Index As Integer) 



If IsArrowKey > 0 Then Exit Sub 
If Index = 5 Then 

If cboYesNo (Index) .Listlndex = 1 Then chkRecommendation (0) .Value = 1 
Elself Index = 7 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (8) . SetFocus 
' Elself Index » 8 Then 

If cboYesNo (Index) .Listlndex « l Then cboYesNo (9) .SetFocus 
Elself Index = 9 Then ' 

. If cboYesNo (Index) .Listlndex = IThen txtNarrative ( 3 ). SetFocus 
Elself Index = 10 Then 

If cboYesNo (Index) .Listlndex = 1 Then cbolnf ormation ( 7 ). SetFocus 
Elself Index = 11 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (12) .SetFocus 
Elself Index = 12 Then 

If cboYesNo (Index) .Listlndex = 1 Then txtNarrative ( 3 ). SetFocus 
Elself Index = 13 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (14) .SetFocus 
Elself Index = 14 Then 

If cboYesNo (Index) .Listlndex = 0 Then chkRecommendation (8) .Value ■ 1 
Elself Index = 15 Then ' . . . 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (16) . SetFocus 
Elself Index. = 16 Then 

If cboYesNo (Index) .Listlndex = 0 Then 
chkRecommendation ( 6 ) .Value = 1 

Else 
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cboYesNo ( 17 ) . Se tFocus 

End If 
Elself Index = 17 Then 

If cboYesNo (Index) .Lis tlndex = 0 Then 

chkRecommendation (6) .Value = 1 * 
Else 

txtNarrat ive ( 7 ) . Se tFocus 

End If 
Elself Index = .18 Then 

If cboYesNo (Index) .Li st Index = 1 Then cboYesNo ( 19 ). Se tFocus 
Elself Index = 24 Then 

If cboYesNo (Index) .Li st Index = 1 Then cbolnf onnation( 10 ) .Se tFocus- 
End .If 
End Sub 

Private Sub cbo Ye sNo__KeyDown (Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Tfcen 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode * vbKeylieft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboYesNo_KeyUp ( index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboYesNo (Index) .Listlndex -1 
End If 
End Sub' 

Private Sub cboYesNo_Los tFocus (Index As Integer) 



If CheckForTab Then 
If Index = 5 Then 

If cboYesNo (Index) .Listlndex = 1 Then chkRecommendation(O) .Value = 1 
Elself Index = 7 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo ( 8 ). SetFocus 
Elself Index « 8 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (9) .SetFocus 
Elself Index = 9 Then 

If cboYesNo (Index) .Listlndex = 1 Then txtNarrative (3) .SetFocus 
Elself Index ~ 10 Then 

If cboYesNo (Index) .Listlndex = 1 Then cbolnf ormat ion (7) .SetFocus 
Elself Index = 11 Then 

If cboYesNo (Index) .Listlndex = 1 Then cboYesNo (12) .SetFocus 
Elself Index = 12 Then > 

If cboYesNo (Index) -Listlndex » 1 Then txtNarrative (3) -SetFocus 
Elself Index » 13 Then 

If cboYesNo (Index) -Listlndex = 1 Then cboYesNo (14) . SetFocus 
Elself Index = 14 Then 

If cboYesNo (Index) .Listlndex = 0 Then chkRecommendation (8) .Value = 1 
Elself Index = 15 Then 

If cboYesNo (Index) .Listlndex « 1 Then cboYesNo (16) .SetFocus 
Elself Index = 16 Then 

if cboYesNo (Index) -Listlndex - 0 Then 
chkRecommendation (6) .Value = 1 

Else 

cboYesNo (17) .SetFocus ' 
End If 
Elself Index = 17 Then 

If cboYesNo (index) -Listlndex m 0 Then 

chkRecommendation (6) .Value = 1 
Else 

txtNarrative ( 7 ) . SetFocus 
End If 
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Elself Index = 18 Then 

If cboYesNo (Index) .Listlndex - 1 Then cboYesNo (19) .SetFocus 
Elself Index =24 Then 

If cboYesNo (Index) -Listlndex = 1 Then cboln format! on ( 10) .Set Focus 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey =0 
End Sub " 

Private Sub cmdAssess_Click() 

Call GetAssessxnentTab 
End Sub 

Private Sub cmdAssess_LostFocus () 

If CheckForTab Then 

Call GetAssessxnentTab 
End If 
End Sub 



Private Sub cmdClear_Click() 

IsArrowKey = 20 
IsNewRecord = True 
clearData IstBenefits, False 
clearData cboStaffs f False 
clearData txtsocial, True 
clearData txtNarrative, True 
clearData chkGoals, True 
clearData cboYesNo, True 
clearData cboAgree, True 
clearData chkTrigger, True 
clearData cboDif f iculty, True 
clearData cboRating, True 
clearData chkRecommendation, True 
clearData cboRecommend, True I 
clearData cbolnf ormation. True 

rst.Open "Select BiggestProblem, Crisis, Crises From Registration Where ConsuroerlD = " & Custon 
ID & _ 

■ And Agency = ■ " & AgencyCode & " * And CaseNumber = » " & CaseNumber & _ 
" * Order by FinishDate", cnn, adOpenForwardOnly, adLockReadOnly 
LoadDataToControls rst, cbolnf ormation (0) , False 

If rst! [Crisis] = "1" Then LoadDataToControls rst, IstCrises. False 
rst. Close 

rst.Open "Select Age,AgeAtOnset, Diabetes, TroubleDiabetes , Hearing, MentionHearing, CheckHeari 
, Abuse, ° & _ . 

"Confusion, Delay, Elderly, Frail, Housing, Legal, Neglect, NoPayer, NoSupportive, Nol 
From" & _ 

"• Triage Where ConsumerlD = ■ & CustomerlD & " And Agency = ■ » & AgencyCode & _ 
■ ■ And CaseNumber = •" & CaseNumber & "• Order by FinishDate ASC", cnn, _ 
adOpenForwardOnly, adLockReadOnly 

With rst 

.MoveFirst 

If IsNumeric (Trim{ ! [Age] ) ) Then txtsocial (17 ) ■ CLng( ! [Age] ) 

If IsNumeric (Trim (! [AgeAtonset] ) ) Then txtsocial (16) = ! [AgeAtonset] 

LoadDataToControls rst, cboYesNo (0), False 

LoadDataToControls rst, cboYesNo (1), False 

LoadDataToControls rst, cboYesNo (2), False 

LoadDataToControls rst, cboYesNo (3) , False 

LoadDataToControls rst, cbo In format ion (1) , False 

LoadDataToControls rst, chkTrigger, True 
End With 
rst .Close 



If Not rstSocial.BOF Then rstSocial .MoveFirst 
txtCurrentRecord = "" 
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cmdPr int. Enabled = False 

cmdSave . Enabled = True , 
tabSocial.Tab - 0 
IsArrowKey =0 
End Sub 

Private Sub cmdClbse_jClick( )* 
Unload Me 
End Sub 

Private Sub cmdHistorical_Click< ) 

IsVisuallnfoClicked = True j 

f rmEyeData . Show vbModal 
End Sub 

Private Sub cmdNext_Click ( ) 

If tabSocial.Tab = 9 Then , „„ ' "♦- 

MsgBox "It is last page for Assessment already! % vblnformatxon + vbOKOnly, Next Page 

Else 

tabSocial.Tab ~ tabSocial.Tab + 1 . 
* frmSocialWork. Caption - getTabCaption(tabSocial .Tab) 

End If 
End Sub 

Private Sub cmdNExtRecord_Click ( ) 

With rst Social 
. MoveNext 

If .AbsolutePosition ■ 1 Then 

cmdPreviousRecord . Enabled = False 

cmdNExtRecord. Enabled = True. 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord. Enabled.= True 

cmdNExtRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

.cmdNExtRecord. Enabled = False 
End If ■ 

If lsNumeric(Trim( ! [Age] ) ) Then 

txtsocial(17) » CLng< 1 [Age] > 

Call DevelopmentDelayGUI 
End If * 

txtCurrentRecord = .AbsolutePosition 
txtSeguencyNo = ! [Assessment Sequence] 
LoadDataToControls rstSocial, IstCrises, False 
IjoadDataToControls rstSocial, IstBenefits, False 
LoadDataToControls rstSocial, cboStaffs, False 

LoadDataToControls rstSocial, txtsocial, True , 

LoadDataToControls rstSocial, txtNarrative, True 

LoadDataToControls rstSocial, chkGoals, True 

LoadDataToControls rstSocial, cboYesNo, True 

LoadDataToControls rstSocial, cboAgree, True 

LoadDataToControls rstSocial, chkTrigger, True 

LoadDataToControls rstSocial, cboDif f iculty. True 

LoadDataToControls rstSocial, cboRating, True 

LoadDataToControls rstSocial, chkRecommendation, True 

LoadDataToControls rstSocial, cboRecommend , True 

LoadDataToControls rstSocial, .cbolnformation, True 

If I [FinishDate] * -12:00:00 PM" Then 

cmdSave. Enabled = True 
Else 

cmdSave. Enabled = False 
End If 
End With 



tabSocial.Tab = 0 
txtCurrentRecord . SetFocus 
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End Sub 

Private Sub cmdPrevious_Click ( ) 

If tabSocial.Tab = 0 Then 

MsgBox "It is first page for Historical Information already!", vblnformation + vbOKOnly, "P. 
iouse Page" 



tabSocial.Tab = tabSocial.Tab - 1 

frmSocialWork. Caption = getTabCaption(tabSocial .Tab) 
End If 
End Sub 

Private Sub cmdPreviousRecor6L_ClickO 

With rstSocial 
. MovePrevious. 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord. Enabled = False 

cmdNExtRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
%v cmdPreviousRecord. Enabled = True' 

cmdNExt Record. Enabled - True 
Elself .RecordCount = -AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNExt Record. Enabled = False 
End If 

If ! [FinishDate] = "12:00:00 PM" Then 

cmdSave : Enabled = True 
Else 

cmdSave. Enabled = False 
End If 

If IsNumeric (Trim( ! [Age] ) ) Then 

txtsocial(l7) a CLng(! [AgeJ ) 

Call DevelopmentDelayGUI 
End If \ 

txtCurrentRecord = .AbsolutePosition 
txtSequencyNo = ! [ Assessment Sequence J • 
LoadDataToControls rstSocial, IstCrises, False 
LoadDataToControls rstSocial, IstBenefits, False 
LoadDataToControls rstSocial, cboStaffs, False 
LoadDataToControls rstSocial, - txtsocial, True 
LoadDataToControls rstSocial, txtNarrative, True 
LoadDataToControls rstSocial, chkGoals,. True* 
LoadDataToControls rstSocial, cboYesNo, True 
LoadDataToControls rstSocial, cboAgree, True 
LoadDataToControls rstSocial, chkTrigger, True 
LoadDataToControls rstSocial, cboDif f iculty, True 
LoadDataToControls rstSocial, cboRating, True 
LoadDataToControls rstSocial, chkRecommendation, True 
LoadDataToControls rstSocial, cbdRecommend, True 
LoadDataToControls rstSocial, cbo Information, True 
End With \ 

tabSocial.Tab =0 
txtCurrentRecord. SetFocus 
End Sub 

Private Sub cmdPrint_Click( ) 
Dim i As Integer 

If Printers. Count » 0 Then 

MsgBox "No printer found associating with this computer. Please add a printer to it and thei 
ou can print but the Service agreement ! » , . _ 
vblnformation + vbOKOnly, "Printer* 

Else 

If rst, State = adStateOpen Then rst. Close 
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rst.Open "Select * From SocialWorkAgreement Where AssessmentSequence = " & txtSequericyNo, c 
adOpenDynamic, adLockOptimistic 

If Not rst.BOF Then 1 if there an- existing report, delete it then create a new report 

rst. Delete 
End If 
rst. Close 

If rst. State » adStateOpen Then rst. Close 

rst.Open "Select * from SocialWorkAgreement Where Assessment Sequence = " & txtSequencyNo , c 
adOpenKeyset, adLockOptimistic 
With rst 

If .BOF And .EOF Then 
.AddNew 

! [CaseNumberl = txtCaseNumber. 
*! [Episode] = txt Episode 
I [Asses sment Sequence! = txtSequencyNo 
! [ConsumerName] = txtConsumerName 
J [Asses smentDate] = txtsocial (13) 
! [Staff Name] = cboStaf f s . Text 
For i = 0 To chkGoa Is. Count - 1 
If chkGoals (i)'. Value = 0 Then 

.Fields (chkGoals (i) .Tag). = 00 
Else ' 

. .Fields (chkGoals (i) .Tag) = "Yes" 
End If 
Next 

For i « 20 To 23 

. Fields (cboYesNo(i) .Tag) = cboYesNo(i) -Text 
Next 

For i = 18 To 21 

.Fields (cbolnformation(i) .Tag) = cbolnf ormation ( i ) .Text 
Next 

.Fields ("Comments 0 ) = txtsocial (15) .Text 
.Update 
End If 
End With. 

Set SocialWorkAgreement .Da taSource « rst 

SocialWorkAgreement .Print Report 
End If • 
End Sub 

Private Sub cmdRecommendation_Click( ) 
Dim response As Integer 

response = MsgBox ( ■ Based on what you assessed on social issues, We recommend the following goa 
0 Ask Consumer if he or she agrees to the recommendations. If Yes, the consu 

must" &. 

" agree at least to one of the Objectives for the Goal.". vbOKOnly, _ 
"Recommended Goal") 

End Sub 

Private Sub cmdRecommendat ion_Lost Focus ( ) 
Dim i As Integer f 

* 

If CheckForTab Then 

For i a 0 To chkRecommendat ion. Count - 1 
If chkRecommendation(i) .Vaiue = 1 Then 
GoalPosition = i 
If i <= 4 Then 

chkRecommenda t ion ( i ) . Set Focus 
Exit Sub 
Else 

tabSocial.Tab =8 
chkRecommendation(i) .SetFocus 
Exit Sub 
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End If 
End If 
Next 

tabSocial . Tab = 8 

txt social (11). Se tFocus 
End If 
End Sub 

Private Sub cmdSave_Click( ) 
' Dim i As Integer 

Dim colSocial As New Collection 

On Error GoTo errSave 

colSocial. Add IstCrises 
colSocial. Add IstBenefits 
colSocial. Add cboStaffs 
colSocial. Add txtspcial 
colSocial. Add txtNarrative 
colSocial. Add chkGoals 
colSocial .Add cboYesNo 
colSocial -Add cboAgree 
colSociad-Add chkTrigger 
colSocial. Add cboDif f iculty 
colSocial. Add cboRating 
colSocial. Add chkRecommendation 
colSocial. Add cboRecommend 
colSocial. Add cboln formation 

r 

If SaveDataToDB(frmSocialWork, rstSocial, colSocial, "010", False) Then 'Call public £x 

ction to save data to DB 

MsgBox "Successfully saved the Assessment information!", vbOKOnly, "Save" 

If IsDate(txtsocial(13) ) Then 

cnn. Execute "Update Interventions Set PreConsumerScore » & txtConsumerScore & PrePi 
vider Score = • ° & _ 

txtProviderScore & » • Where Consumer ID = ■ & CustomeriD & ■ And Agency = ' " & AgencyCoc 

" 1 And Episode = ■ & Episode & ■ And CaseNumber =» 1 " & CaseNumber & _ 

And InterventionlD = '010«- And (EndDate = #12:00:00 PM# or EndDate IS NULL)" 

cnn. Execute "UPDATE SocialAssessment AS a INNER JOIN Interventions AS b ON (a. CaseNumber = 
b . CaseNumber ) " & _ 

AND (a. Episode = b. Episode) AND (a.ConsumerlD = b.ConsumerlD) SET a.InterventionSeaue 
ce = b.InterventionSequence" & 

' _ " b. InterventionlD = 1 010' and b. CaseNumber = *" & CaseNumber & ■ " AND (b. EndDate 

= #12:00:OOPM# OR b. EndDate IS NULL) " & _ 
" AND a.InterventionSequence = 0" 

End If 

If IsNewRecord Then 
rstSocial . Requery 

txtSequencyNo = rstSocial ! [Assessment Sequence 3 
End If 

IsNewRecord = False 

Set colSocial a Nothing 
End If 
Exit Sub 

errSave: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save" 

End Sub - 

Private Sub cmdTrigger_Click( ) 
Dim response As Integer 

response = MsgBox<»From Triage, following checked trigger (s) promoted a Social Service assessmen 
* — * 
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Private Sub cmtfrrigger_LostFocus ( ) 
Dim i As Integer 

If CheckForTab Then 

For i • 0 To chkTrigger. Count - 1 
If chkTrigger (i)'. Value = 1 Then 
TriggerPosition = i 
chkTrigger ( i) .SetFocus 
Exit Sub 
End If 
Next 
End If 
End Sub 

Private Sub CombolJ*ostFocus (Index As Integer) ' 
If Index = 0 Then 

tabSocxal.Tab = 1 
"El self Index = 1 Then 

tabSocial.Tab =9 
End If 
End Sub 

Private Sub Form_Activate ( ) 

Dim j As Integer . 

On Error GoTo Errhandler 

If IsVisuallnfoClicked Then Exit Sub 

txtConsumerName = FirstName & ■ " & LastName * 
txt Phone = PhoneNo 

txtAddress = Address 
txtCaseNumber = CaseNumber 
txt Episode = Episode 
txtlntervention = ° Social Service" 

LoadControlsitems cboStaffs, False 'Add every description from database to combobox or li« 

tbox 

IsArrowKey = 20 •Avoid Click event when load data from database 

Set rst* = New ADODB. Recordset 
rst .CursorLocation = adUseClient 

Set rstSocial = New ADODB. Recordset 
rst Social. CursorLocation = adUseClient 

rstSocial. Open "Select * From SocialAssessment Where ConsumerlD = .° & Customer ID & _ 

• ° And Agency = ■ ° & AgencyCode & ■ ' And Episode - " & Episode & ■ And CaseNumber « 1 " & _ 
CaseNumber & ■• And Interventions = '010' Order By AssessmentSequence DESC", cnn, _ 
adOpenKeyset ; adliOckQptimistic 

With rstSocial 

txtRecordNo - .RecordCount 

If Not (.EOF And -BOF) Then 'Have record for this client and load it to form 

If IsNumeric (Trim( ! [Age] ) ) Then 
txt social ( 17 ) = CLng ( 1 [Age] ) 
Call DevelopmentDelayGUI 
End If 
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vbOKOnly , ■ Trigger ■ ) 



End Sub 



txtCurrentRecord = .AbsolutePosition 
txtSequericyNo = ! [AssessmentSequence] 
LoadDataToControls rstSocial, IstCrises, False 
LoadDataToControls rstSocial; IstBenefits, False 
LoadDataToControls rstSocial, cboStaffs, False 
LoadDataToControls rstSocial, txtsocial. True 
LoadDataToControls rstSocial, txtNarrative, True 
LoadDataToControls rstSocial, chkGoals, True 



frmSocialWork - 14 • ^ m ^ tm 

60^3 ®^O.S .« OJL 3L 

LoadDataToControls rstSocial, cboYesNo, True. \ 

LoadDataToControls rstSocial, cboAgree, True 

LoadDataToControls rstSocial, chkTrigger, True 

LoadDataToControls rstSocial, cboDif f iculty. True 

LoadDataToControls rstSocial, cboRating, True 

LoadDataToControls rstSocial, chkRecommendation, True 

LoadDataToControls rstSocial, cboRecommend, True 

LoadDataToControls rstSocial, cbolnf ormation. True 

If .RecordCount > .AbsolutePosition Then cmdNExtRecord. Enabled = True 

If ! [FinishDate] <> "12:00:00 PM° And IsDate ( ! f FinishDate] ) Then 

cmdSave . Enabled = False 

cmdPrint . Enabled = True 

cmdCl ear . Enabled = True 
End If 

Else 

.rst. Open "Select Biggest Problem, .Crisis, Crises From Registration Where ConsumerlD * 6 
stomerlD, 

cnn, adOpenForwardOnly, adLockReadOnly 
LoadDataToControls rst, cbolnf ormation ( 0 ) , False 

If rst! [Crisis] - "1" Then LoadDataToControls rst, lstCrises, False 
rst. Close 

rst Open "Select Age, AgeAtOnset, Diabetes, TroufcleDiabetes, Hearing, MentionHearing, Ct 
Hearing, Abuse, 0 & _ 37 

From" & " Confusion ' Delav > Elderly, Frail, Housing, Legal, Neglect, NoPayer, NoSupportive, Nc 

eNumber ~ ^t* 9 * ***** ConsumerID = " & CustomerlD & • And Agency = »■ & AgencyCode & ■ • And 

Witt a 5?** >er * 9 ' Episode = ' * ^ isod e, cnn, adOpenForwardOnly, adLockReadOnly 

.MoveFirst 

If IsNumeric (Trim (! [Age])) Then 

txtsocial (17) s CLng( ! [Age J > 

Call DevelopmentDelayGUI 
End If l 

If IsNumeric ( Trim (! [AgeAtonset] ) ) Then txtsocial (16) « ! (AgeAt onset] 

LoadDataToControls rst, cboYesNo(O), False 

LoadDataToControls rst, cboYesNo(l), False 

LoadDataToControls rst, cboYesNo(2), False 

LoadDataToControls rst, cboYesNo(3), False 

LoadDataToControls rst, cbolnf ormation(l) , False 

LoadDataToControls rst, chkTrigger, True 
End With 
rst. Close 

cmdNExtRecord. Enabled = False 
cmdPreviousRecord. Enabled = False 
txtCurrentRecord = 0 
End If 
End With 



IsArrowKey = 0 
chkTrigger (3) -Value = 1 
tabSocial.Tab = 0 
txtConsumerName . SetFocus 
Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 

Private Sub Form_Unload (Cancel As Integer) 
Dim response As Integer 

.If isFileDateChecked Then 

If rstSocial. state = adStateOpen Then rstSocial. Close 
Set rstSocial = Nothing 
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tabSocial.Tab =0 
Set frmSocialWork = Nothing 
Else 

If Trim (txt social (13) ) = ° ° And cmdSave. Enabled Then 

response = MsgBox(°Have you finished the Social Service Assessment ? a , vbQuestion + vbYe 
, "Pile Date 0 ) 

If response = vbYes Then 

MsgBox "Please enter the File Date I", vblnformation + vbOKOnly, D File Date" 
txtsocial(13) .SetFocus 
Cancel = True 
Else 

If rstSocial. State = adStateOpen Then rstSocial .Close 
. Set rstSocial = Nothing 
tabSocial.Tab = 0 
Set frmSocialWork = Nothing 
End If 

Elself IsDate(Trim(txtsocial (13) ) ) And cmdSave. Enabled Then 

response = MsgBox ( "Are you sure you finished the Social Service Assessment?", vbQuestion 
vbYesNo, "File Date") 

If response = vbYes Then 

MsgBox "Please use Save button to save the assessment information" , vblnformation + 
KOnly, "File Date" 

cmdSave . SetFocus 
Elself cmdSave . Enabled = True Then 

txtsocial(13) s 
End If 

• Elself . IsDate(Trim(txtsocial<13) ) ) And Not cmdSave. Enabled Then 
If rstSocial. State =• adStateOpen Then rstSocial .Close 
Set rstSocial = Nothing 
tabSocial ,Tab = 0 
Set frmSocialWork = Nothing 
End If 
End If 
End Sub 

Private Sub IstBenef its_KeyUp(KeyCode As Integer, Shift As Integer) 
Dim i As Integer 

If KeyCode = vbKeyBack Then 

If IstBenef its.SelCount = 1 Then 

IstBenef its. Selected (Is tBenef its. Lis tlndex) = False 
Elself IstBenef its .Lis tCount > 1 Then. 

For i » IstBenef its .Lis tCount - 1 To 0 Step -1 
• If IstBenef its. Selected (i) Then . 
IstBenef its .Selected (i) « False 
End If 
Next 
End If 
End If 
End Sub 

Private Sub IstBenef it s_Lost Focus () 

If Not IstBenef its. Selected(5) Then txt social (14) .SetFocus 
End Sub * 

Private Sub tabSocial_Click(PreviousTab As Integer) 
Dim j As Integer 

If tabSocial.Tab = 0 Then 
cboStaf f s . SetFocus 
TriggerPosition =0 

frmSocialWork. Caption = n A. Historical Information". 
Elself tabSocial.Tab = 1 Then 

frmSocialWork. Caption = "B. No Support Network/Isolation" 
Elself tabSocial.Tab = 2 Then 

cbopifficulty(3) .SetFocus 

frmSocialWork. Caption = D C. Frailty" 
Elself tabSocial.Tab = 3 Then 

If Not IsHousinglssues Then 
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D. Development Delay" 
21 Then 



fnnSocialWork. Caption = 
If CInt(txtsocial(17)) < 

cboYesNo{7) .SetFocus 
Else 

cboYesNo (10). SetFocus 
End If 
End If 

Elself tabSocial.Tab = 4 Then 

fnnSocialWork. Caption = °E. 
Elself tabSocial.Tab « 5 Then 

cboDifficulty (9) .SetFocus 
- fnnSocialWork. Caption ■ "P. Abuse/Neglect 
Elself tabSocial.Tab - 6 Then 

fnnSocialWork. Caption a °G 
Elself tabSocial.Tab = 7 Then 

cmdRecommendation . SetFocus 

fnnSocialWork. Caption = °H 
Elself tabSocial.Tab = 8 Then 

fnnSocialWork. Caption « °i 
Elself tabSocial.Tab = 9 Then 

fnnSocialWork. Caption = "J 

cmdGoal . SetFocus 

CountGoals 
End If 



Legal Issues 0 



No Payer Available" 



Recommended Goals" 
Recommended Goals 0 
Social Service Agreement" 



End Sub 

Private Function getTabCaption (tablndex As Integer) As String 



Select Case tablndex 
Case 0 

getTabCaption = 
Case 1 

getTabCaption = 
. Case 2 

getTabCaption = 
Case 3 

getTabCaption = 
Case 4 

getTabCaption = 
Case 5 

getTabCaption = 
Case 6 

getTabCaption = 



°A. Historical Information" 

°B. No Support Network/ Isolation 0 

n C. Frailty" 

n D. Development Delay" 

"E. Legal Issues" 

°F. Abuse/Neglect" 

"G. No Payer Available" 



Case 7 

getTabCaption = n H. Recommended Goals" 
Case 8 

getTabCaption = "I.. Recommended Goals" 
Case 9 

getTabCaption = "J. Social Services Agreement 0 
End Select 
End Function 



Private Sub CountScoreO 

Dim i As Integer 

Dim tmpValue As Integer 

Dim taskA As Long 

Dim tasks As Long 

Dim avgScore As Single 

For i = 0 To cboDifficulty. Count - 1 'count the score for task A 

If cboDifficulty (i) .List Index » — 1 Then 

taskA = taskA + 4 
Else 

tmpValue = cboDif f iculty (i) . ItemData (cboDifficulty (i) -Listlndex) 
taskA = taskA + tmpValue 
End If 
Next 



tmpValue = 0 
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For i = 0 To cboRa ting. Count - 1 

If cboRating(i) .Listlndex = -1 Then 'user does'nt select one, count 10 for this item 

taskB = taskB +10 
Else 

tmpValue = cboRating(i) . Iten©ata(cboRa ting (i) .Listlndex) 
taskB = taskB + tmpValue 
End If 
Next 



txtProviderScore = taskB * 1.1 

txtGonsumerScore « taskA * 1.7 

avgScore = ((taskA * 1.7) + (taskB * 1.1)) / .2 

txt social (11) = Cling (avgScore) 

txtsocial{18) = Format (taskA * 1.7, "##") 

txtsocial(19) = Format (taskB * 1.1, "##") 

txtsocial(20) = Format (avgScore, "##") 



Select Case CLng( avgScore) 



Case 0 To 60: 
Case 61 To 80: 
Case 81 To 90: 
Case 91 To 100: 

End Select 

End Sub 



txtsocial(12) 
txtsocial(12) 
txtsocial(12) 
txtsocial (12) 



"Level 3° 
"Level 2" 
"Level 1 B 

"No Service Needed 0 



Private Sub txtNarrative_LostFocus (Index As Integer) 
Dim i As Integer 

If CheckForTab Then 
If Index = 3 Then 

If TriggerPosition >- 10 Then 
tabSocial.Tab = 7 
cmdRec ommenda t i on . SetFocus 
Else 

For i = TriggerPosition + 1 To chkTrigger . Count - 1 
* If chkTrigger (i) .Value =: 1 Then 
TriggerPosition = i 
Call Get Assessment Tab 
Exit Sub 
End If 
Next 

tabSocial.Tab = 7 
cmdRec ommenda t ion . SetFocus 
End If 
End If 
End If 
End Sub 

Private Sub GetAssessmentTab( ) 
Dim i As Integer, j As Integer 

For i = TriggerPosition To chkTrigger. Count - 1 
If i = 3 Then 

TriggerPosition = i 

tabSocial.Tab = 1 

cboYesNo ( 4 ) . SetFocus 

Exit For 
End If 

If chkTrigger (i) .Value ■ 1 Then 
If i = 0 Then 

TriggerPosition = i 
tabSocial.Tab = 5 
Exit For 
Elself x = 1 Then 

TriggerPosition = i 
..tabSocial.Tab « 2 

frmSocialWork. Caption = • Confusion /disoren tat ion" 
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cboDifficulty(S) .SetFocus 
Exit For. 
Elself i = 2 Then 

If Not IsHousinglssues Then 

TriggerPosition = i 

tabSocial .Tab = 3 

•frmSocialWork.Caption .= "Development Delay 0 

End If 

Exit For 
Elself i = 4 Then 

Trigger Posit ion = i 

tabSocial. Tab = 2 

frmSocialWork. Caption = "Frailty" 

cboDif ficulty(3) .SetFocus 

Exit For 
Elself i - 5 Then 

IsHousinglssues = True 

Trigger Position = i 

tabSocial. Tab = 3 

frmSocialWork. Caption = "Housing Issues" 
cboDifficulty(6) .SetFocus 
Exit For 
Elself i = 6 Then 

TriggerPosition =* i 
tabSocial . Tab 4 

frmSocialWork. Caption = "Legal Issues" 
cboYesNo.(24) .SetFocus 
Exit For 
Elself i = 7 Then 

If chkTrigger(O) -Value « 0 Then 

TriggerPosition = i 

tabSocial. Tab = 5 

cboDifficultyO) .SetFocus 

Exit For 
End If * 
Elself i = 8 Then 

TriggerPosition = i 
tabSocial . Tab = 6 . 

frmSocialWork .Caption = "No Payer Available 
cbolnformation (14) .SetFocus 
Exit For 
Elself i = 10 Then 

TriggerPosition = i 
tabSocial. Tab = 6 

frmSocialWork. Caption = "Refuse to pay" 
cbolnformation (15) .SetFocus 
• Exit For 
End If 
End If 
Next 
End Sub 

Private Sub CountGoalsO 
Dim i As Integer 

For i = 0 To cboAgree . Count - 1 
Select Case i 
Case 0 .To 3 

If cboAgree (i) .Text = "Yes" Then chkGoals(O) = 1 
Case 4 

If cboAgree (i) .Text « "Yes" Then chkGoals(l) = 1 

Case 5 To 9 i „ 

If cboAgree (i) .Text = "Yes" Then chkGoals(2) = 1 

Case .10 To 11 % 

If cboAgree (i) -Text = "Yes" Then chkGoals(3) = 1 

Case 12 To 15 

If cboAgree (i) .Text = "Yes" Then chkGoals(4) = 1 

Case 16 To 17 _ 4 - 

If cboAgree (i) .Text = "Yes" Then chkGoals(5) = 1 

Case 18 To 20 
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If cboAgree(i) -Text « "Yes" Then chkGoals(6) « 1 

Case 21 To 22 

If cboAgree(i) .Text = "yes 11 Then chkGoals(7) = 1 

Case 23 To 25 

If cboAgree(i) .Text = °Yes" Then chkGoals(8) = 1 

Case 26 To 27 

If cboAgree(i) .Text = "Yes" Then chkGoals(9) =1 

° aS If 2 cboAgree(i) .Text = °Yes° Then chkGoals(lO) = 1 
End Select 
Next 

End Sub , 

Private Sub txt Socialist Focus (Index As Integer) 

If checkForTab Then 

If index = 10 Then txtNarrativeO) . SetFocus 

End If 
End Sub 

private Sub DevelopmentDelayGUI ( ) 
Dim j As integer 

If cint (txtsocial (17)) <= 21 Then 
For j = 0 To 5 

lblDelay (j ) .Visible = True 
Next , 

cboYesNo(7) .Visible = True 
cboYesNo(8) .Visible = True 
cboYesNoO) .Visible = True 
cboInformation(5) .Visible True 
txtsocial (2) .Visible = True 
• txtsocial (3) .Visible = True 

lblDelay (14) -Caption = "3. Narrative:" 

Else \ 
For j - " 6 To 13 

lblDelay (j) - Visible = True 
Next * 

cboYesNo(lO) .Visible = True 
cboYesNo (ID -Visible = True 
cboYesNo (12). Visible * True 
cboInformation(6) .Visible = True 
cboInformation(7) .Visible = True 
cboInformation( 8) .Visible = True 
- txtsocial (4) .Visible * True' 
txtsocial (5) .Visible = True 

End If 
End Sub 
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Option Explicit 

Private tmp Episode As Integer 

Private chkLocation As Integer 

CheckBox 

Private IsSighted As Boolean 
Private IsShf tTab As Boolean 
Public IsNewRecord As Boolean 
Private ServiceLocation As Integer 
Private IsFileDateChecked As Boolean 
Private rstTriage Us ADODB . Recordset 
Private IsArrowKey As Integer 



•to remember the location of Service Recommnedat 



Private Sub* cboAcceptReject_KeyUp( Index As Integer,. KeyCode As Integer, Shift As Integer) 
If KeyCode = vbKeyBack Then 

cboAcceptReject (Index) .List Index = -1 
End If ■ 
End Sub 

Private Sub cboAcceptReject_LostFocus (Index As Integer). • 

Dim i As Integer 

Dim IsRecommented As Boolean 

Dim HasOtherReason As Boolean 

If CheckForTab And cboAcceptReject (Index) .Text = "Rejected" Then 

cboRejec tionReason ( Index) . SetFocus 
Elself CheckForTab And cboAcceptReject (Index) .Text <> "Rejected" Then 
For i = ServiceLocation To chkRecommendation. Count - 1 
If chkRecommendation (i) -Value = 1 Then 
ServiceLocation =* i 
chkRecommendation ( i ) -SetFocus 
IsRecommented = True 
Exit Sub ' 
End If 
Next 

If Not IsRecommented Then 

For i = 0 To ServiceLocation 

If cboRejectionReas^nCi) .Listlndex = 5 Then 
txtTriage(lO) .SetFocus 
HasOtherReason » True 
End If 
Next 

If Not HasOtherReason Then 
tabTr iage . Tab = 6 
cmdlnst ruction. SetFocus 
End If 
End If • 
Elself CheckForShftTab Then 

chkRecommendation ( Index) .SetFocus 
Else 'If user manully select one "Accepted" cpmbo, its service is recommended 

If cboAcceptReject (Index) .Text = "Accepted" And chkRecommendation (Index) .Value = 0 Then 

chkRecommendation (Index) .Value = 1 
End If 
End If 
End Sub 

Private Sub cboActionStatus_KeyUp (KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboActionStatus. List Index = -1 . 
End If 
End Sub 

Private Sub cboActivity_Click( ) 
If IsArrowKey > 0 Then Exit Sub 

If cboActivity.Listlndex = 2 Or cboActivity. List Index = 3 Then 
cboYesNo(28) .Listlndex = -1 
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cboFrequency2 . SetFocus 
End If 
End Sub 

Private Sub cboActiyity_KeyDown( KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUfc Then 

IsArrowKey « KeyCode 
El self KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey » KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboActivity__KeyUp ( KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboActivity. List Index = -1 
End If 
End Sub 

Private Sub cboActivity._LostFocus { ) 

If CheckForShftTab Then 

If Triin(txtTriage<20) ) <> ° ° Then 

If CInt(Trim{txtTriage(20) ) ) < 18 Then 
isShftTab = True 
tabTriage . Tab = 3 
cboYesNo (19). Se t Focus 
Else 

cboYesNo(27) .SetFocus 
End If 
End If 
Elself CheckForTab Then 

If cboActivity.Listlndex = 2 Or cboActivity. Listlndex = 3 Then cboFrequency2 . SetFocus 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboAgree_Click( Index As Integer) 
If IsArrowKey > 0 Then Exit Sub ■ 

If Index = 0 Then 

If cboAgree(O) .Text = "Yes" Then IstRace . SetFocus 
Elself Index = 1 Then 

If cboAgree(O) .List Index = 0 Then 
cboAgree(l) .List Index = -1 

Else 

If cboAgree(l) -Text = "Yes" Then 

chkRecommendation(O) .Value = 1 
Else 

chkRecommendation(O) .Value = 0 
End If 
End If 
End If 
End Sub 

Private Sub cboAgree_KeyDown ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
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El self keyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If 
End Sub 

Private Sub cboAgree _keyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboAgree ( Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboAgree_Lost Focus (Index As Integer) 

If Index = 0 Then 

If CheckForTab Then 

If cboAgree (0) .Text = "Yes" Then IstRace . SetFocus 
End If 
Elself Index = 1 Then 
If - CheckForTab Then 

If cboAgree (0) -Listlndex - 0 Then 

cboAgree (1) .Liqtlndex = -1 
Else , 
If cboAgree (1) .Text = "Yes" Then 

chkRecommendation(O) .Value = 1 
Else 

chkRecommendation(O) .Value = 0 
End If 
End If 
End If 
End If 

If IsArrowKey <> 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboDenyReason_Lost Focus ( ) 

If CheckForTab Then . 

tabTriage.Tab = 6 » 

cmdlnstruct ion . SetFocus 
End If 
End Sub 

Private Sub cboEpisodeOutcome_KeyUp (KeyCode As Integer, Shift As Integer) . 
If KeyCode = vbKeyBack Then 

cboEpisodeOut come. Lis tlndex =' -1 
End If 
End Sub • 

Private Sub cboFrequency2_Click( ) 
If IsArrowKey > 0 Then Exit Sub 

i 

End Sub 

Private Sub cboFrequency2_KeyUp ( KeyCode As Integer, Shift As Integer) 

If KeyCode vbKeyBack Then 

cboFrequency2 .Listlndex = -1 
Elself KeyCode » vbKeyUp Then 

IsArrowKey = KeyCode 
• Elself KeyCode - vbKeyDown Then 

IsArrowKey = KeyCode 
5lself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 

Elself KeyCode = vbkeyLeft Then v 

IsArrowKey = KeyCode ' 
End If 
End Sub 
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Private Sub cboFrequency2 .jLost Focus ( ) 

If CheckForShftTab Then 

If cboActivity. Listlndex = 0 Or cboActivity. List Index = 1 Then 

cboYesNo (28) .SetFocus 
Else 

cmdFactors . SetFocus 
End If 
End If 

If cboFrequency2 . Listlndex = 2 Or cboFreguency 2 .List Index = 3 Then cmdFactors. SetFocus 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboOveral 1 Heal th_Click (Index As Integer) 
If IsArrowKey > 0 Then Exit Sub 
If* Index's 1 Then 

If cboOverallHealth (1) .Listlndex = 0 Or cboOverallHealth ( 1 ) .List Index = 1 Then 
cboYesNo (7) -Listlndex = -1 
cboYesNo ( 8) .List index = -1 
cboYesNo ( 9 ) . SetFocus 

Elself cboOverallHealth (1) .Listlndex = 2 Or cboOverallHealth (1) .Listlndex = 3 Then 
cboYesNo ( 7 ) . SetFocus 

End If 
End If 
End Sub 

Private Sub cboOverallHealth_JCeyDown( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyUp Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyDown Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyRight Then 

IsArrowKey = KeyCode 
Elself KeyCode = vbKeyLeft Then 

IsArrowKey = KeyCode 
End If * 
End Sub 

Private Sub cboOverallHealth_JCeyUp< Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboOverallHealth (Index) .Listlndex = -1 
End If 
End Sub 

Private Sub cboOverallHealth_J*ostFocus (Index As Integer) 

If Index = 0 Then 

If CheckForShftTab Then ■ 
IsShftTab = True 
tabTriage.Tab « 0 
If IsSighted Then 

txtTriage(l) .SetFocus 
Elself cboYesNo (2) .Text = u Yes" Then 

cboYesNo (4) .SetFocus 
Else . 

txtTriage(l) .SetFocus 
End If . 
End If 
Elself Index o. 1 Then 

If CheckForShftTab Then 

If cboYesNo (5) .Text = "No" Then cboYesNo (5) . SetFocus 
Elself CheckForTab Then 

If cboOverallHealth (1) .Listlndex = 0 Or cboOverallHealth (1) .Listlndex » 1 Then 
cboYesNo (9) .SetFocus 
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Elself cboOverallHealth(l) .List Index = 2 Or cboOverallHealth(l) .List index = 3 Then 

cboYesNo ( 7 ) . Se tFocus 
End If 
End If 
End If 

If IsArrowKey > 0 Then IsArrowKey = 0 
End Sub 

Private Sub cboRejectionReason_KeyUp< Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then » 
cboRejectionReason( Index) .Lis tlndex = -1 

End If 
End Sub 

Private Sub cboRejectionReasonl_Los tFocus (Index As Integer) 

Dim i As Integer 

Dim IsRecommented As Boolean 

Dim HasOtherReason As Boolean 

Dim totalRecommendation As Integer 

Dim totalRejection As Integer 

If CheckForTab Then 

For i = ServiceLocation + 1 To* chkRecommendation. Count - 1 
If chkRecommendation (i) .Value = 1 Then 
ServiceLocation = i 
chkRecommendation ( i ) .SetFocus 
IsRecommented = True 
' Exit Sub 
End If 
Next 
End 'If 



If Not IsRecommented Then 

For i = 0 To ServiceLocation 

If cbpRejectionReason(i) .List Index = 5 Then 

txtTr iage (10). SetFocus . 
HasOtherReason = True 
End If 

Next . 

If Not HasOtherReason And CheckForTab Then 
For i = 0 To chkRecommendation .Count - 1 

If chkRecommendation (i) .Value =» 1 Then totalRecommendation = totalRecommendation + 1 
Next 

For i = 0 To cboAcceptReject .Count - 1 

If cboAcceptReject (i) .Text « "Rejected" Then totalRejection = totalRejection + 1 
Next 

If totalRecommendation = totalRejection Then 

cboDeny Reason. SetFocus * 
Else 

tabTriage.Tab = 6 
cmdlnstruction.Se tFocus 
End If 
End If 
End If 
End Sub 

private Sub cboYesNo_Click( Index As Integer) 
Dim i As Integer 

If IsArrowKey > 0 Then Exit .Sub 

If Index = 0 Then 

If cboYesNo (Index) .Lis tlndex = 0 Then 
cboYesNo (1) .Lis tindex = -1 
cboYesNo ( 2 ) . Li s tlndex = - 1 
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txtTriage ( 1 ) . SetFocus 

End If 
Elself Index - 1 Then 

If cboYesNo (0) .Listlndex = 0 Then 
cboYesNo (Index) -Listlndex - -1 
Elself cboYesNo (Index) .Listlndex « 0 Then 

txtTriage (1) .SetFocus 
End If 
Elself Index = 2 Then 

If cboYesNo(O) -Listlndex = 0 Or cboYesNo (1) .Listlndex = 0* Then 

cboYesNo ( Index ) . Li s t Index = - 1 
End If 

Elself Index = 3 Or Index = 4 Then 
If cboYesNo (2) .Listlndex = 1 Then 
cboYesNo (Index) .Listlndex = -1 
End If. 
Elself Index = 5 Then 

If cboYesNo (Index) .Listlndex <> 0 Then 
cboYesNo (6) .Listlndex = -1 
cboOverallHealth(l) .SetFocus 
• End If 
Elself Index = 6 Then * 

If cboYesNo (5) .Listlndex <> 0 Then cboYesNo (Index) .Listlndex = -1 

If cboYesNo (Index) .Text = "Yes" Then . . ^ 

chkRecommendation(2) .Va^Lue = 1 'If yes to have trouble managing your diabetes, 

chkRecommendationO) .Value = 1 ' recommend Diabetes Management & IDT 

End If 

Elself Index = 7 Or Index = 8 Then ■ 
If cboOverallHealth(l) .Listlndex = 0 Or cboOverallHealth(l) .List index = 1 Ttxen 

cboYesNo (Index) -Listlndex = -1 
End If 
Elself Index = 9 Then 

If cboYesNo (9) .Text = "Yes" Then 

Is tHealthCondition. SetFocus 
Else 

txtTriage (4) .SetFocus 
End If 
Elself Index = 10 Then 

If cboYesNo (Index) .Listlndex = 0 Then 

cmdMovement . SetFocus 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation(l) .Value = 1 
End If 
Elself Index = 11 Then 

If cboYesNo (10) .Listlndex = 0 Then 

cboYesNo (11) .Listlndex = -1 

cmdMovement . SetFocus 
Elself cboYesNo (Index) .Listlndex » 0 Then 

If cboYesNo (2) -Listlndex = 0 Then chkRecommendation(l) .Value = 1 

End If 
Elself Index = 12 Then 

If cboYesNo (Index) .Listlndex = 0 Then 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation(l) .Value = 1 

chkRecommendation(6) .Value =1 

cmdHousehold. SetFocus 
End If 
Elself Index = 13 Then 

If cboYesNo (12) .Listlndex = 0 Then 

cboYesNo (13) .Listlndex = -1 

cmdHousehold . SetFocus 
Elself cboYesNo (Index) .Listlndex = 0 Then 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation(l) .Value = 1 

chkRecommendation(6) -Value = 1 
End If . 
Elself Index = 14 Then 

* If cboYesNo (Index) .Listlndex = 0 Then 

For i = 0 To 2 'If partially sighted, rec LV 

If cboYesNo (i) .Text = "Yes" Then chkRecommendation(l) .Value = 1 
Next 



chkRecommendation(5) .Value = 1 
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tabTriage . Tab = 3 
cmdPsychological . Set Focus 
End If 

Blself Index = 15 Then v 

If cboYesNo (14) .Listlndex = 0 Then 

cboYesNo (15) .Listlndex = -l 
Elself cboYesNo ( 15) .Listlndex = 0 Then 

chkRecommendation (5) .Value =1 

cmdPsychological .SetFocus 
Else 

cboYesNo (16). SetFocus 
End If 

tabTriage . Tab =3 
Elself Index =16 Then 

If cboYesNo ( 14 ), Listlndex = 0 Or cboYesNo (15) .Listlndex = 0 Then 

cboYesNo (16) .Listlndex = -1 
Elself CboYesNo (16) .Listlndex = 0 Then 
chkRecommendation ( 5 ) .Value = 1 
cmdPsychological . SetFocus 
' Else 

cboYesNo ( 17 ) . SetFocus 
End If 
Elself Index = 17 Then 

If cboYesNo (14) .Listlndex = 0 Or cboYesNo ( 15 )'. List Index = 0 Or cboYesNo (16) .Listlndex = 

hen 

cboYesNo (17) .Listlndex = -1 
cmdPsychological . SetFocus 
Elself cboYesNo (Index) .Listlndex = 0 Then 

chkRecommendation (5) .Value =1 
End If 
Elself Index = 18 Then 

-If cboYesNo (Index) .Listlndex <> -1 Then cboYesNo ( 19 ), SetFocus 
If cboYesNo (Index) .Listlndex = 0 Then chkRecoinmendation(4) .Value = 1 
Elself index = 19 Then 

If cboYesNo (Index) .Listlndex <> -1 Then 
If cboYesNo (18) .Listlndex - -1 Then 

MsgBox "Please answer Question 1!", vblnf ormation + vbOKOnly, « Psychological Statu 
cboYesNo (18). SetFocus 
Elself cboYesNo (19) .Listlndex = 0 Then chkRecommendation (4) . Value = 1 
End If 
End If 
Elself Index =20 Then 

If cboYesNo (Index) .Listlndex = 1 Then 

cboYesNo ( 23 ) . SetFocus * 
Else 

cboYesNo ( 21 ) . SetFocus 
End If 

Elself Index = 21 Or Index = 22 Then 

If cboYesNo(20) .Listlndex = 1 Then cboYesNo (Index) .Listlndex = -1 
Elself Index = 23 Then 

If cboYesNo (Index) .Text = "Yes" Then 

If cboAgree(O) .Text = "Yes" Then 'Yes to like to be employed and is Citizen 

chkRecommendation (9) .Value = 1 
cboYesNo ( 25 ) . SetFocus 
Elself cboAgree(O) .Text = tt No tt Then 'Yes to like be employed and is not citizen 

cboYesNo (24) .SetFocus 
End If 

Elself cboYesNo (Index) .Text = "No 0 Then 
If Trim(txtTriage(20) ) <> Mn Then 

If CInt(txtTriage(20) ) >= 18 Or CInt ( txtTriage (20) ) <= 64 Then chkRecommendation (9) .V 

e = 1 

End If 
End If 
Elself Index = 24 Then 

If cboYesNo (Index) .Text = "Yes" Then. 

chkRecommendation (9) -Value. = 1 
Elself cboYesNo (Index) .Text = "No" Then 

cboYesNo (26), SetFocus 
End If • 
Elself Index =25 Then 
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If cboYesNo( Index) .Text = "Yes" Then chkRecommendation ( 10) .Value «■ 1 
Elself Index = 26 Then ' Computer Skills 

If cboYesNo(26) .Text = 0 Yes° Then chkRecommendation (8) lvalue = 1 
Elself index = 27 Then 1 Computer Skills 

If cboYesNo(27) .Text = "Yes 0 Then chkRecommendation (8) .Value = 1 

ElS If f cboAc^ivitJ.Listlndex = 2 Or cboActivity. List Index = 3 Then cboYesNo (Index) .List Index = - 

End If 
End Sub 

Private Sub cbo Ye sNo_KeyDown (Index As Integer, KeyCode As Integer, Shift -As Integer) 

Select Case KeyCode 
Case vbKeyDown 

IsArrowKey = KeyCode 
Case vbKeyRight 

IsArrowKey = KeyCode 
Case vbKeyLef t 

IsArrowKey = KeyCode 
Case vbKeyRight 

IsArrowKey = KeyCode 
End Select- 
End Sub 1 

Private Sub cboYesNo„KeyU& ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If KeyCode = vbKeyBack Then 

cboYesNo ( Index) .Listlndex = -1 
End If 
End Sub; 

Private Sub cboYesNo_Lost Focus (Index As Integer) 
Dim i As Integer 

If Index = 0 Then , 
If CheckForTab Then 

If cboYesNo (0) .Text = "Yes" Then txtTriage(l) .SetFocus 

End If 
Elseli Index =1 Then 
If CheckForTab Then 

If cboYesNo(l) .Text = "Yes" Then txtTriage ( 1 )- SetFocus 
End If 
Elself Index = 2 Then 
If CheckForTab Then 

If cboYesNo (2) .Text = "No" Then 
cboYesNo (3) .Tabs top = False 
cboYesNo (4) .Tabs top = False 
txtTriage (2 ) .TabStop = False 
Else 

cboYesNo (3) .TabStop - True 
CboYesNo (4) .TabStop = True 
txtTriage (2) .TabStop = True 
End If 
End If 

ElS If f cboYesNo(4) .Text = -Yep" And cboYesNo (2) -Listlndex = 0 Then chkRecommendat ion (1) .Value 

If CheckForTab' Then tabTriage.Tab = 1 
Elself Index « 5 Then 
If CheckForTab Then 

If cboYesNo (5) .Text = "Yes; Then 

cboYesNo ( 6 ) . SetFocus 
Else 

cboOverallHealth(l) .SetFocus 
End If 
End If 
Elself Index = 6 Then 
If CheckForTab Then 

If cboYesNo (6) .Text = n Yes a Then 
chkRecommendat ion (2) .Value = 1 
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chkRecommendation (3) .Value = 1 
End If . 
End If 
El self Index = 9 Then 

If CheckForShftTab Then 

If cboOyerallHealth(l) .Listlndex = 0 Or cboOverallHealth(l) .Listlndex = 1 Then 

cboOverallHealtfc ( 1 ) . SetFocus 
End If 
Elself CheckForTab Then 
• If cboYesNoO) .Text = "Yes° Then 
IstHealthCondition . SetFocus 
Else 

txtTriage ( 4 ). SetFocus 
End If 
End If 
Elself Index =10 Then 
If CheckForTab Then 

If cboYesNo( Index) .Text = "Yes" Then 

l£ cboYesNo (2) .Listlndex = 0 Then chkRecommendation (1) .Value = 1 
cmdMovement . SetFocus 
End If 
End If 
Elself Index = 11 Then 
If CheckForTab Then 

If cboYesNo(lO) .Text = "Yes" Then 
cboYesNo(ll) .Listlndex = -1 
cmdMovement . SetFocus 
Elself cboYesNo(ll) .Text = "Yes" Then 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation (1) -Value = 1- 
End If 
End If - 
Elself Index = 12 Then 

If CheckForShftTab Then 

If IsSighted Or cboYesNo (2) .Text = "No" Then 

cmdProbl em. SetFocus 
Else 

cboYesNo (11) .SetFocus 
End If 

Elself CheckForTab Then * 

If cboYesNo (Index) .Text = "Yes" Then 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation (1) .Value * 1 
chkRecommendation ( 6 ) .Value = 1 
cmdHousehold . SetFocus 
End If 
End If 
Elself Index = 13 Then 
If CheckForTab Then 

If cboYesNo (12) .Listlndex = 0 Then 
cboYesNo (13) .Listlndex = -1 
cmdHousehold . SetFocus 
Elself cboYesNo (Index) .Text = "Yes" Then 

If cboYesNo (2) .Listlndex = 0 Then chkRecommendation (1) .Value = 1 
chkRecommendation (6) .Value - 1 
End If 
End If 
Elself Index = 14 Then 
If CheckForTab Then 

For i = 0 To 2 'If partially sighted / rec LV 

If cboYesNo (i) .Text = "Yes" Then chkRecommendation (1) .Value = 1 
Next 



If cboYesNo (Index) .Text = "Yes" Then 
chkRecommendation (5) .Value = 1 
tabTr iage . Tab = 3 
cmdPsychological . SetFocus 
End If 
End If 
Elself Index = 15 Then • 
If CheckForShftTab Then 
• cboYesNo ( 14 ) . SetFocus 
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Elself CheckForTab Then 

If cboYesNo (14) .Listlndex = 0 Then 

cboYesNo (15) .Listlndex = -1 

tabTriage.Tab =3 

cmdPsychological . SetFocus 
Elself cboYesNo (15) .Listlndex = 0 Then 

chkRecommendation(5) .Value = 1 

tabTriage.Tab = 3 

cmdPsychological . SetFocus 
Else 

tabTriage.Tab =3 
cboYesNo (16) .SetFocus 
End If 
End If 
Elself Index = 16 Then 

If CheckForShftTab Then 
IsShftTab = True 

tabTriage.Tab = 2 ( 
cboYesNo (15) .SetFocus 
Elself CheckForTab Then 

If cboYesNo (15) .Listlndex = 0 S*hen 
CboYesNo (16) .Listlndex = -1 
cmdPsychological . SetFocus 
Elself cboYesNo (16) .Listlndex = 0 Then 
chkRecommendation(5) .Value = 1 
tabTriage.Tab =3 
cmdPsychological . SetFocus 
End If 
End If 
Elself Index = 17 Then 
If CheckForTab Then 

If cboYesNo (16) .Listlndex = 0 Then 
cboYesNo (17) .Listlndex = -1 
cmdPsychological . SetFocus 
El s el f cboYesNo ( Index ) . Li s t Index « 0 Then 
chkRecommendation(5) .Value = 1 
tabTriage.Tab =3 
cmdPsychological . SetFocus 
End If 
End If 

Elself Index = 18 Or Index = 19 Then 
If CheckForTab Then 

If Index « 19 And Trim(txtTriage(20) ) <> Then 
If CInt(txtTriage(20) ) < 18 Then 
tabTriage.Tab = 4 
cboActivity . SetFocus 
End If 
End If 

If cboYesNo (Index) .Text = "Yes" Then chkRec ommendat ion (4) .Value = 1 

If Index = 19. Then 

Zi cboYesNo (19) -Listlndex <> -1 And cboYesNo (18) .Listlndex = -1 Then 

MsgBox "Please answeer Question 1 !", vblnf ormation + vbOKOnly, "Psychological Statt 

0 

cboYesNo ( 18 ) . SetFocus 
Elself cboYesNo (19) .Listlndex - -1 Arid cboYesNo (18) .Listlndex <> -1 Then 

MsgBox "Please answeer Question 2 «», vblnf ormation + vbOKOnly, "Psychological Stati 

a 

J cboYesNo ( 19 ) . SetFocus 

End If ■ 
End If 
End If 
Elself Index « 20 Then 
If CheckForTab Then 

If CboYesNo (Index) .Text ■ "No" Then cboYesNo( 23) .SetFocus 
End If 
Elself Index = 21 Then 

If cboYesNo (Index) .Text . = "Yes" Then chkRecommendation (9) .Value = 1 
Elself Index « 22 Then 
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If Not CheckForShf tTab Then 

If cboYesNo (Index) .Text = °Yes° Then 

chkRecommendat ion (9) .Value = 1 

cboActionStatus.Listlndex = 1 
End If 

cboYesNo(25) .SetFocus 
End If . ' 
El self Index = 23 Then 
If CheckForTab Then 

- If cboYesNo ( Index) .Text = "Yes" Then 

If cboAgree(O) .Text - "Yes" Then 'Yes to like to be employed and is Citizen 

chkRecommendation(9) .Value = 1 
* cboYesNb(25) .SetFocus 
Elself cboAgree(O) .Text = °No° Then 'Yes to like be employed and is not citizen 

cboYesNo (24). SetFocus 
End If 

Elself cboYesNo ( Index) -Text = "No" Then 
If Trim (txt Triage (20 ) ) <> " 0 Then 

If CInt(txtTriage(20) ) >= 18 Or CInt ( txtTriage (20) ) <= 64 Then chkRecommendation(9) . 

alue =1 

End If 
End If 
End If 
Elself Index = 24 Then 
If CheckForTab Then 

If cboYesNo( Index) .Text = "Yes" Then 

chkRecommendation(9) .Value = 1 
Elself cboYesNo ( Index) .Text = "No" Then 

cboYesNo (26) .SetFocus 
End If 
End If 
Elself Index =25 Then 

If cboYesNo (Index) .Text = "Yes" Then chkRecommendat ion (10) .Value = 1 
Elself Index = 26 Then 
If 'CheckForTab Then 
tabTriage . Tab =4 

If cboYesNo (26) -Text = "Yes 0 Then chkRecommendat ion (8) .Value = 1 ■ Computer Skills 

End If . 
Elself Index = 27 Then 1 
If CheckForShftTab Then 

IsShftTab = True 

tabTriage . Tab = 3 

cboYesNo (26) .SetFocus 

If cboYesNo (27) .Text = "Yes" Then chkRecommendation(8) .Value = 1 1 Computer Skills 

End If 
Elself Index =28 Then 

If cboYesNo (Index) .Text = "Yes" Then chkRecommendat ion (0) .Value = 1 
Elself Index =30 Then 
If CheckForTab Then 

If cboYesNo (30) .Text <> "Yes" Then txtTriage (15) .SetFocus 
End If 
End If 

If IsArrowKey <> 0 Then IsArrowKey = 0 
End Sub 



Private Sub chkFac t or s_Lost Focus (Index As Integer) 

If chkFac tors (Index) .Value = 1 Then chkRecommendat ion ( 0 ) .Value = 1 

If Index = 12 And CheckForTab Then tabTriage. Tab = 5 
End Sub 

Private Sub cmdAppoiments_Click( ) * H 

MsgBox "Make assessment appointments in each accepted area. Instruct consumer to bring" & _ 

■ any eyeglasses or optical devices to appointments", vblnformation + vbOKOnly, "Appoime: 

s" 

End Sub 

Private Sub cmdAppoiments.JECeyUptKeyCode As Integer, Shift As Integer) 



i 
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If KeyCode = vbKeyBack And (Shift And vbShiftMask) > 0 Then tabTriage . Tab = 7 
End Sub 

Private Sub cmdAppoiments_LostFocus ( ) 
If CheckForShftTab Then 
IsShftTab = True 
cboActionStatus . SetFocus 
tabTriage . Tab =6 
End If 
End Sub 

2^.S^ C S25£2rS5Si21it. in each accepted area. Instruct consumer to bring any eyeg 

asses or optical devices to appointments 0 , vbOKOnly, "Appointment 

tabTriage . Tab =0 

cboSex . SetFocus 

tabTriage . Tab = 6 

txtTriage(16) .SetFocus 

End Sub 

Private Sub cmdAppoitments_JiOStFocus () 

If CheckForShftTab Then . 

tabTriage. Tab = 6 

cboActionStatus . SetFocus 
End If 
End Sub 

Private Sub cmdClose_Click () 
Unload Me 
End Sub 

Private Sub cmdFac tor s_C lick ( ) 
Dim response As Integer 

responsf^^gBo^-Recoinmendations for Social Service Assessment - check all that apply". vbOKO 

y, "Risk Factors 0 ) 

If response = vbOK Then 

tabTriage -Tab =4 

chkFactprs(O) .SetFocus 
End If 

End Sub # 

Private Sub cmdFactors_JjOstFocus () 

If CheckForShftTab Then . ' 

If cboFre<iuency2.IiistIndex = 0 Or cboFrequency 2 .List Index = 1 Tnen 

cboYesNo(29) .SetFocus 
Else 

cboFrequency2 . SetFocus 
End If 
End If 
End Sub 

Private. Sub cmdInstruction_Click ( ) 

MsgBox -If ANY recommendations are accepted, EYE REPORT must be requested. 0 , vbOKOnly, "Service 

nstruction" 

tabTriage .Tab =0 

cboSex . SetFocus 

tabTriage. Tab =6 

txtTriage ( 11 ) . SetFocus 

End Sub 

Private Sub cmdlns true tion_fcost Focus ( ) 
If CheckForShftTab Then 
. IsShftTab = True 
tabTriage. Tab =5 
txtTriage (10). SetFocus 
End If' 



ia 9 e - 13 £>D»£397aS ..0.1:1.3. 

End Sub 

Private Sub cmdClear_Click< ) 

IsNewRecord = True 
IsFileDateChecked = False 
clearData cboStaffs, False 
clearData cboYesNo, True 
clearData txtTriage, True 
clearData IstHealthCondition, False 
clearData cboAcceptReject, True 
clearData cboRejectionReascm, True 
clearData cboActionStatus, False 
clearData cboActivity, False 
clearData cboFrequency2 , False 
clearData chkFactors, True 
clearData chkRecommendation, True 
clearData cboOverallHealth, True 
clearData cboEpisodeOutcome, False 
clearData cboDenyReason, False 
clearData cbo70B, True 
clearData chk70B, True 

With rstTriage 

If Not . BOF Then 
t MoveFirst 

LoadDataToControls rstTriage, cboSex, False 
cboSex . Locked = True 

txtTriage (0) .Text ■ .Fields . I tern ( "Birthdate" ) 
txtTriage (0) .Locked = True 

LoadDataToControls rstTriage, cboAgree, True 
LoadDataToControls rstTriage, cboAgree, True 
LoadDataToControls' rstTriage, IstRace, False. 
End If 
End With 

cmdSave. Enabled = True 
tabTriage . Tab = 0 . 
cboSex . SetFocus * ' 
End Sub 

Private Sub crodNext_Click( ) 

If tabTriage . Tab = 7 Then 

MsgBox °It is last page for Triage already!", vblnf ormation + vbOKOnly, "Next Page" 
Else 

tabTriage . Tab = tabTriage . Tab +1 
frmTriage. Caption = getTabCaption (tabTriage. Tab) 
End If 
End Sub 

Private Sub cmdNExtRecord_Click{ ) ~* 

With rstTriage 
.MoveNext 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord. Enabled = False 

cmdNextRecord. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 

cmdPreviousRecord . Enabled = True 

cmdNextRecord. Enabled = True 
Elself .RecordCount = . .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNextRecord. Enabled = False 
End If 

txtEpisode. = 'Episode 

LoadDataToControls rstTriage, cboStaffs, False 

LoadDataToControls rstTriage, cboSex, False 

LoadDataToControls rstTriage, cboYesNo, True 
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txtTriage, True 
IstHealthCondition, False 
cboAcceptReject, True 
cboRejectionReason, True 
cboActionStatus , False 
cboActivity, False 



LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 

LoadDataToControls rstTriage, cboFrequency2 , False 
LoadDataToControls rstTriage, chkFactors, True 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 



cbo70B, True 

cboServiceLocation, False 
cboEpi sodeOu tcome , Fal se 
cboDenyReason , False 
chk7QB, True 



And ! (FinishDate] & vbNullString <> "12:00:00 PM° 



If 1 [FinishDate] « "12:00:00 PM° Then 

cradSave . Enabled = True 
Else 

cmdSave. Enabled - False 
End If 

If IsDate( I [FinishDate J & vbNullString) 

IsFileDateChecked = True 
End If 
End With- 

tabTriage.Tab » 0 

End Sub - 
private Sub cmdPrevious_Click( ) 

" SEED'S firsfSge for Triage already!", vbxnfor^ation * vbOKOnly, -Previouse Page- 

ElS tabTriage.Tab = tabTriage.Tab - 1 

frmTriage. Caption = getTabCapt ion (tabTriage.Tab) 

End If 
End Sub 



Private Sub cmdPreviousEpisode — Click () 



With rstTriage 
. MovePrevious 
If . AbsolutePosition 



1 Then 



'Have record. for this client and load it 



orm 



cmdPreviousRecord. Enabled = False 
cmdNextRecord. Enabled = True' 
Else 

cmdPreviousRecord. Enabled = True 
cmdNextRecord. Enabled = True 
End If 



If i [FinishDate] * 
cmdSave . Enabled 

Else 

cmdSave • Enabled 

End If 



8 12 : 00 : 00 PM° Then 
= True 

= False 



txtEpisode » 'Episode 
LoadDataToControls rs tTr iage , 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
End With 



cboYesNo, True 
txtTriage, True 
.IstHealthCondition, False 
cboAcceptReject, True 
cboRe j ec t i onRea s on , True 
cboActionStatus , False • 
cboActivity, False 
cboFrequency2 , Fal se 
chkFactors, True 



tabTriage.Tab 
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txtEpisode . SetFocus 
.End Sub 

Private Sub cmdPreviousRecoro_Click( > 

With rstTriage 

.MovePrevious . „ _ 

If .AbsolutePosition = 1 Then 

cmdPreviousRecord. Enabled - False 
cmdNextRecord . Enabled = True 

Blself .AbsolutePosition < .RecordCount Then 
cmdPreviousRecord. Enabled * True 
cmdNextRecord . Enabled = True • 

Elself .RecordCount = .AbsolutePosition Then 
cmdPreviousRecord. Enabled = True 
cmdNextRecord. Enabled = False 

End If . 



60439700 .-OaL± 



txtEpisode = i Episode 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage, 
LoadDataToControls rstTriage 



cboStaffs, False 
cboSex, False 
cboYesNo, True 
txtTriage, True 
Is tHeal thCondi tion , False 
cboAcceptRe ject , True 
cboRejectionReason, True 
cboActionStatus, False 
cboActivity, False 
cboFrequency2 , False 
chkFactors, True 
cbo70B, True 



LoadDataToControls rstTriage, — . 

LoadDataToControls rstTriage, cboServiceLocation, False 
LoadDataToControls rstTriage, cboEpisodeOutcome, False 
LoadDataToControls rstTriage, cboDenyReason. False 
LoadDataToControls xstTriage, chk70B, True • 

If l [FinishDate] » "12:00:00 PM» Then 

cmdSave. Enabled * True 
Else 

cmdSave . Enabled- = False 
End If 

■ if isDateO (FinishDate] « vbNull String) And .[FinishDate] U vbNullString <> "12:00:00 PM« 
IsFileDateChecked = True 
End If 
End With 

tabTriage.Tab =0 

End Sub - 

Private Sub cmdProblem__Click ( ) 
Dim response As Integer 

On Error GoTo Errhandler 

£5Snsr: T X g Lx(. AS a reS ult of your vision impairment, are you^having problems in the fo 

g areas?-*, ^ & yes an6wer to any questions move on to the next area unless otto 

specif *_ prompt8 a recommendation for asS essment. in that area.-, vbOKOnly. -Problen 

If response = vbOK Then 

tabTriage.Tab « 2 
End If • 
Exit Sub 



Errhandler : . 

MsgBox Err. Description & 

End Sub 



Err. Number. vbCritical + vbOKOnly. "Problem Click 0 



On Error GoTo Errhandler 

If CheckForShftTab Then 

IsShftTab = True 

tabTriage.Tab = 1 

txtTr iage ( 9 ) . Set Focus 
Elself CheckForTab .And (XsSighted Or cboYesNo(2) .Text = "No") Then 

cmdMo vemen t . Set Focus 
End If 
Exit Sub 

Errhandler: 

MsgBox Err. Description & ■ " & Err. Number, vbCritical + vbOKOnly, "Problem Lost Focus" 
End Sub 

Private Sub cmdRecommendation_Click( ) 
Dim Str As String - 
Dim response As Integer 

Str = "Describe training and services that could address the problems identified. Recommend add: 

zonal seervices if necessary." & vbNewLine & vbNewLine 

Str = Str & "Recommendations Rules:" & vbNewLine 

Str = Str & "* Age 18-64 : Career Services" & vbNewLine 

Str = Str & "* Age 14-64 and agree to career services: Career CP. If 14-64 and rejects career s 
rvices, SWCP (notify CP to suggest • Career Services)" & vbNewLine 

Str = Str* & "* Assign a Career CP On-Call if career services are desired (academic. Computer si 
lis) and status is Ordinary" & vbNewLine 

Str ■ Str & "* If employed and agrees to LV (but not Career): SWCP and recommend Career Assessx 
nt" & vbNewLine 

Str « Str & "* Assign- a SWCP and recommend Social Service Assessment if any Risk Factors were : 
dicated, and also if caller is age 80 or older" & vbNewLine 

Str - Str & "* All cases marked as Crises or Urgent: SWCP - Intensive level, UNLESS the only f« 

tor is danger or losing job, then assign Career CP - Intensive level" & vbNewLine 

Str = Str & "* All cases that do not meet the above criteria - SWCP On-Call" & vbNewLine 

Str - Str & vbNewLine* 

MsgBox Str, vbOKOnly, "Recommendation" 

Str = "Based on your responses, the following services would be beneficial to you." 

Str a Str &. " Mark each recommended area with Accepted Or Rejected,- and if rejected, a reason" 

MsgBox Str, vbOKOnly, "Recommendation" 

tabTriage.Tab =0 
cboSex . SetFocus 
tabTriage.Tab = 5 
chkRecommendation(O) .SetFocus 
End Sub 

Private Sub cmdRecbmmendation^LostFocus ( ) 

Dim i As. Integer 

Dim Accept Services As Boolean 

If CheckForShftTab Then 
IsShftTab = True 
tabTriage.Tab =5 
Elself CheckForTab Then 

For i = 0 To chkRecommendat ion. Count - 1 
If chkRecommendation(i) .Value = 1 Then 
ServiceLocation = i 

If tabTriage.Tab = 5 Then chkRecommendation(i) .SetFocus 
Exit Sub 
End If 
Next 

If ServiceLocation = 0 Then 
tabTriage.Tab =7 
cmdlns true t ion . SetFocus 
End* If 
End If 
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Private Sub cmdProblem_.LostFocus ( ) 
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End Sub 

Private Sub cmdSave_Click ( ) 

Dim i As Integer 

Dim tmpStr As String 

Dim colTriage As New Collection 

Dim rst As New ADODB . Recprdset 

On Error GoTo errSave 

If Not IsFileDateChecked Then 

txtTriage (19) = 0 n 'Guarantee No End Date, then No episode close date 

If IsNewRecord Then txtEpisode = frmMainMenu.cboEpisode.ListCount + 1 

If Trim(txtRecordNo) = n 0 n Then txtEpisode = 1. 

colTriage. Add cboStaffs . 

colTriage. Add cboSex 

colTriage. Add cboAgree 

colTriage. Add IstRace 

colTriage. Add cboYesNo 

colTriage. Add txtTriage 

colTriage. Add txtEpisode 

colTriage. Add IstHealthCondition 

colTriage. Add cboAcceptReject 

colTriage .Add cboRejectionReason 

colTriage. Add cboActiohStatus 

colTriage. Add cboActivity 

colTriage . Add cboFrequency2 , 
colTriage . Add chkFactors 
colTriage. Add chkRecommendation 
colTriage. Add cboOverallHealth 
colTriage. Add cbo70B 

colTriage. Add chk70B nn . * 

If SaveDataToDB(frmTriage, rstTriage, colTriage, "O", False) Then 'Call public rune 

on to save data to DB 

MsgBox "Successfully saved the Triage inf ormation ! n , vbOKOnly, ?Save B 



0 Accepted * Then 



If IsDate (Trim ( txtTriage < 18) ) > Then 

For i = 0 To chkRecommendation. Count - 1 

If chkRecommendation (i) .Value = 1 And cboAcceptReject (i) .Text 
If i = 0 Then 

tmpStr = "010" 
Elself i = 1 Then 

tmpStr « "041" 
Elself i ■ 2 Then 

tmpStr « O 047" 
Elself i = 3 Then 

tmpStr a *Q45 n 
Elself i = 4 Then 

tmpStr = "Oil 0 
Elself i = 5 Then 

tmpStr = "013° 
Elself i = 6 Then 

tmpStr = "014" 
Elself i = 7 Then 

tmpStr = °031° 
Elself i = 8 Then 

tmpStr « "160° 
Elself i « 9 Then 

tmpStr ■ "050° 
Elself i = 10 Then ■ 

tmpStr = "056" 
Elself i = 11 Then 

tmpStr = °141 n 
Elself i = 12 Then 

tmpStr = n 121 D 
End If 

If tmpStr <> on Then , 

cnn. Execute "Insert into Interventions (Consumer ID, Agency, Episode, CaseNumber, 

erventionID,StartDate) ■ & _ 
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-Values ( 8 & CustomerlD & d , 1 " & AgencyCode & "'," & Trim( txtEpisode) & " , 1 n & 
aseNumber & ■ ■ , • ■ & tmpStr & _ 

■ • # ■ ° & Date & 0 ■ ) " 
End If 
tmpStr = °° 

End If 
Next 
End If 

cmdSave . Enabled = True . _ . 

If isDate(Trim(txtTriage(18))) And Trim(txtTriage (18) ) <> "12:00:00 PM" Then isFileDateCh 

Iced ~ True 

Elself IsDate(Trim(txtTriage(18))) And IsDate(Trim(txtTriage (19) ) ) Then 
cmdSave . Enabled = False 
End If 

Elself IsDate(Trim(txtTriage(19))) And Trim(txtTriage(19) ) <> "12:00:00 PM" Then • Update Epis 
eCloseDate after all the work is done . 

cnn. Execute "Update Triage Set EpisodeCloseDate = #° & txtTriage(19) & n # n & _ 

"Where ConsumerlD = n & CustomerlD & ■ And Agency « 1 ■ & AgencyCode & & _ 

"And Episode = ° & Episode & » And CaseNumber = 1 " & CaseNumber & n • " 

End If 

IsNewRecord = False 
Set colTriage = Nothing 
Exit Sub t 

errSave : 

MsgBox Err. Description, vbCritical +» vbOKOnly, "Save" 
End Sub 

Private Sub cmdShortKeys_Click ( ) „w m - 
MsgBox "Press Alt O for shortcuts" & vbNewtine & "Press Alt I to Save Payer Information & vbNe 

»Press~Alt A for the Authorizations Screen" & vbNewLine & "Press Alt W to enter a New Payer" & 

^Press S Alt"E to move to the Previous Payer" & vbNewLine & "Press Alt F to move to the Next Pay* 
, vbOKOnly, 
End Sub 

Private Sub Form_X*oad ( ) 

Set rstTriage « New ADODB .Recordset 
rstTriage.CursorLocation = adUseClient 
End Sub 

Private Sub Form_Unload (Cancel As Integer) 

f rmMainMenu - cboEpisode . Clear 
rstTriage . Requery 
With rstTriage 

If Not (.BOF And .EOF) Then 
.MoveFirst 
While Not .EOF 

f rmMainMenu. cboEpisode. Addltera 1 [Episode] 
. MoveNext 
Wend 
End If 
End With 

f rmMainMenu. txtEpisodeCloseDate = txtTriage(19) 
If txtTriage(19) = OB Then 

f rmMainMenu. Label2. Visible = False 
f rmMainMenu. txtEpisodeCloseDate. Visible = False 
Else ' 
f rmMainMenu. Label2. Visible = True 
f rmMainMenu. txtEpisodeCloseDate. Visible = True 
End If 



Private Sub. lstHealthCondition_JKeyUp (KeyCode As Integer, Shift As Integer) 
Dim i As Integer . • 

If KeyCode = vbKeyBack Then 

If IstRace.SelCount = 1 Then 

IstHealthCondition.Selected(lstHealthCondition.Listlndex) = False 
Elself IstHealthCondition.ListCount > 1 Then 

For i = IstHealthCondition.IiistCount - 1 To 0 Step -1 
If lstHealthCondition.Selected(i) Then 

IstHealthCondition.Selected(i) = False 
End If 
Next 
End If 

End If 0 
End Sub 

Private Sub IstHealthConditionJiOstFocus () 

If CheckForTab And Is tHealthCondit ion. Selected (28) Then 

txtTr iage ( 3 ) . SetFocus 
Elself CheckForTab And Not lstHealthCondition.Selected(28) Then 

txtTriage ( 4 ) . SetFocus 
End If 

End Sub . . 

Private Sub Form_Activate ( ) 

Dim i As Integer, j As Integer, k As Integer 
Dim today As Date 

On Error GoTo Errhandler 

txtFirstName * FirstName , 
txtLastName = LastName 
txfcCaseNumber = CaseNumber 

LoadControl si terns cboServiceLocation, False 
LoadControlsI terns cboStaffs, False ( 

rstTr iage . Open "Select Trouble From Registration* Where Consumer ID = ■ & CustomerlD & ° And Agen- 
AgencyCode & a • And CaseNumber = '» & CaseNumber & n 1 " , cnn, adOpenForwardOnly, . 

LockReadOnly 
With rstTriage 

If Not (.BOF And .EOF) Then 
If 1 [Trouble] = 2 Then 

IsSighted = True 
Else 

IsSighted = False 
End If 
End If 
End With 

rstTriage. Close • 

rstTriage. Open "Select * From Triage Where ConsumerlD = ■ & CustomerlD & ° And Agency = ■ " & _ 
AgencyCode & ■» And CaseNumber = • B & CaseNumber & " ■ Order By Tr iageSqe " , cnn, _ 
adOpenDynamic , adLockOptimistic 

With rstTriage 

If Not (.BOF And .EOF) Then 

rstTriage. AbsolutePosition = frmMainMenu.cboEpis ode. Text 
txtRecordNo » .RecordCount 
* txtEpisode = frmMainMenu.cboEpis ode. Text 
LoadDataToControls rstTriage, cboStaffs, False 
LoadDataToControls rstTriage, txtTriage, True 
LoadDataToControls rstTriage, cbo^gree, True 
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If rstTriage. State = adStateQpen Then rstTriage .Clpse 
Set rstTriage = Nothing 
Set frmTriage = Nothing 
End Sub- 



frmrriage - 20 £. O^l-S^ 7 O S3 ,U±^2 

LoadDataToControls rstTriage, cboSex, False 
LoadDataToControls rstTriage, lstRace # False 
LoadDataToControls rstTriage, cboYesNo, True* 
LoadDataToControls rstTriage, IstHealthCondition; False 
LoadDataToControls rstTriage, cboAcceptReject, True 
LoadDataToControls rstTriage, cboRejectionReason, True 
LoadDataToControls rstTriage, cboActionStatus , False 
LoadDataToControls rstTriage, cboActivity, False 
LoadDataToControls rstTriage, cboFrequency2 , False 
LoadDataToControls rstTriage, chkFactors, True 
LoadDataToControls rstTriage, chkRecommendation, True 
LoadDataToControls rstTriage, cboOverallHealth, True 
LoadDataToControls rstTriage, cbo70B, True 
LoadDataToControls rstTriage, cboServiceLocation, False 
LoadDataToControls rstTriage, cboEpisodeOutcome, False 
LoadDataToControls rstTriage, cboDenyReason, False 
LoadDataToControls rstTriage, chk70B, True 

If .RecordCount > 1 Then 

If .AbsolutePosition « i Then 

cmdPreviousRecord. Enabled == False 

cmdNext Record . Enabled = True 
Elself -AbsolutePosition < -RecordCount Then 

cmdPreviousRecord . Enabled = True 

cmdNext Record. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 

cmdPreviousRecord. Enabled = True 

cmdNextRecord. Enabled = False 
End M 

Else , 

cmdNextRecord. Enabled = False 

cmdPreviousRecord. Enabled = False 
End If 

If IsDate ( l [FinishDate] & vbNullString) And ! [FinishDate] & vbNullString <> "12:00:00 PM 

hen 

IsFileDateChecked = True 
.End If 
End If 
End With 

1 If Episode is closed then disable the P.ayer Save and Triage Save buttons 

If IsDate (txtTriage (19) ) Then 

cmdSave. Enabled * False 
End If 

tabTriage . Tab = 0 
txtFirstName . SetFocus 
Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, . "Form Activate" 
End Sub 

Private Sub lstRace_KeyUp(KeyCode As Integer, Shift As Integer) 
Dim i As Integer 

If KeyCode = vbKeyBack Then 

If IstRace. SelCount = 1 Then 

IstRace.Selec ted (IstRace. List Index) False 
Elself IstRace.ListCount > X Then 

For i = IstRace.ListCount - 1 To 0 Step -1 
If IstRace. Selected(i) Then 

IstRace. Selected(i) = False 
End If 
Next 
End If 
End If 
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Private Sub lstRaceJiOS t Focus O 

If CheckForTab Then 
If IsSighted Then 

tabTriage . Tab = 1 . 
cboOveral IHeal th ( 0 ) . Set Focus 
End If 
End If 
End Sub 

Private Sub tabTriage_Click(PreviousTab As Integer) 
Dim Is Accepted As Boolean 
Dim i As Integer 

On Err GoTo Errhandler 

If PreviousTab = 0 Then 

If* txtTriage<0) « ■» Then 

MsgBox 0 Please enter Birthday in this field ! " , vblnf ormation + vbOKOnly, "Birthday " 

tabTriage. Tab =0 

txtTriage(O) .SetFocus 

Exit Sub- 
End If 

If cboAgree(O) = "" Then 

MsgBox "Please answer resident status !.", vblnf ormation +* vbOKOnly, "Resident Status" 

tabTriage . Tab = 0 

cboAgree ( 0 ) . SetFocus 

Exit Sub 
End If 

End If 

If tabTriage -Tab = 0 Then 
cboSex . SetFocus 

frmTriage. Caption = "A. Demographics" 
Elself tabTriage. Tab = 1 Then 

If Not IsShftTab Then cboOverallHealth(O) . SetFocus 

IsShftTab = False 

frmTriage. Caption = 'B'. Health" 
Elself tabTriage. Tab = 2 Then 

If Not IsShftTab Then cmdProblem . SetFocus 

IsShftTab = False ■ ■ 

frmTriage. Caption » "C. Problem ID" 
Elself tabTriage. Tab =.3 Then 

If Not IsShftTab Then cboYesNo( 16) .SetFocus 

IsShftTab = False 

frmTriage. Caption = "D. Problem ID" 
Elself tabTriage. Tab = 4 Then 

If Not IsShftTab Then cboYesNo( 27) .SetFocus 
IsShftTab = False 

If cboYesNo(26) .Listlndex = 0 Then cmdSoci a INeeds. SetFocus 
frmTr iage . Caption = "E. Risk Factors" 
Elself tabTriage. Tab = 5 Then 

If Not IsShftTab Then cmdRecommendation . SetFocus 
IsShftTab = False 

frmTriage. Caption = °F. Recommendations" 
Elself tabTriage . Tab = 6 Then 

If Not IsShftTab Then cmdlnst ruction. SetFocus 
IsShftTab = False 

frmTriage . Caption = "G. Eye Report" 
Elself tabTriage . Tab = 7 Then 

If Not IsShftTab Then cbo7OB{0) .SetFocus 
frmTriage . Caption = "7 -OB" 
IsShftTab b False 

For i a 0 To chkRecommendat ion. Count - 1 ■ 
If chkRecommendation(i) .Value = 1 Then 
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End Sub 
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If cboAcceptReject(i) .Text = "Accepted" Then isAccepted = True 
End If 
Next 
End If 
Exit Sub 

MsgBox^Err! Description & ■ 0 & Err. Number, vbCritical + vbOKOnly, "Tab Click 0 
End Sub 



Private Function Check_Close_Episode() Make sure all goals, objectives, programs are fir 

shed * 

Dim rstCheck As ADODB ! Recordset 1 before we can close the episode 

Dim tmpBuf (10) As String 
Dim tmpMessage As String 

Dim w As Integer , 
Dim v As Integer 

On Error GoTo errSave: 

Set rstCheck = New ADODB . Recordset 

Check_Close_Episode - False , 
' All objectives must be finished 

w = 0 
v = 0 

rstCheck. Open -Select Distinct Description From objectiveAchieve OA, InterventionCodes IC Where 
A. Consumer ID = ° & CustomerlD & _ 

» And OA. Agency = & AgencyCode & «• And OA.CaseNumber » •" & CaseNumber & _ 
And OA. Episode = ■ & Episode & n And (Achievement IS NULL " & _ 

- Or Trim (Achievement) = » & Chr(39) & Chr(39) & " Or CompletionDate IS NULL Or 

ompletionDate = #12:00:00 PM#) ° & _ ^ T ^VT> oa ^n«iv 
■ And OA.InterventionID = IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck. RecordCount > 0 Then 
With rstCheck 

While Not (.EOF) 
If w > 0 Then 

•tmpBuf (v) » tmpBuf (v) & ■ and " 
End If 

tmpBuf(v) = tmpBuf (v) & ! [Description] 
. MoveNext 
w = w + 1 
Wend 

End With » , , . , 

tmpBuf (v) ■ "There are 0 & tmpBuf (v) & " Objectives that are not completed 

Check_Close_Episode = True 

End If 

rstCheck . Close 

1 All goals must be finished 

w = 0 

v = v + 1 

rstCheck. Open "Select Distinct Description From GoalAchieve GA, InterventionCodes IC Where GA.C 
sumerlD - ■ * CustomerlD ^ f ^ & AgencyCode & „ , ^ qa. CaseNumber - - * CaseNumber t _ 

■< And GA. Episode = " & Episode & " And (Achievement IS NULL » & 
« Or Trim(Achievement) = " & Chr(39) & Chr(39) & ■ Or CompletionDate IS NULL Ox 

ompletionDate = #12:00:00 PM#) " & _ _ _ " _ „ 

- And OA.InterventionID = IC.Code",. cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck. RecordCount > 0 Then 
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With rstCheck 

While Not (.EOF) 
If w > 0 Then 

tmpBuf (v) - tmpBuf (v) & n and ° 
End If 

tmpBuf (v) * tmpBuf (v) & ! [Description] 
.MoveNext 
w = w + 1 
Wend 

End With • . a JH 

tmpBuf <v) » vbNewLine & "There are a & tmpBuf (v) & " Goals that are not completed* 
ChecX_Close_Episode = True 
End If 

rstCheck. Close * . 

• All progress reports must be finished 

w = 0 

v = v + 1 

rstCheck. Open "Select Distinct Description From ProgressReport PR, In t erven tionCodes IC 0 & _ 
"Where PR . ConsumerlD = " & Customer ID & _ 
■ And PR. Agency = 1 ■ & AgencyCode & ■ • And PR. CaseNumber = 10 & CaseNumber & _ 
And PR. Episode = n & Episode & 0 And (StaffName IS NULL ■ & _ 

" Or Trim (StaffName) = * & Chr(39) & Chr(39) & 0 Or Summary IS NULL Or Trim(Suira 
ry) = ° & Chr(39) & Chr(39) & _ " 

" Or PeriodFrom IS NULL Or PeriodFrom = #12:00:00 PM# Or PeriodTo IS NULL Or Pe: 

odTo = #12:00:00 PM#)".& _ 

° And PR. Interventions = IC.Code" 

If rstCheck. RecordCount > 0 Then 
With rstCheck- 
While Not (.EOF) 
If w > 0 Then 

tmpBuf (v) * tmpBuf (v)& " and " 
End If 

tmpBuf(v) = tmpBuf (v) & ! [Description] 
.MoveNext 
w = w + 1 
Wend 

End With , . 

tmpBuf (v) = vbNewLine & "There are " & tmpBuf (v) & " Progress Reports that are not completed 

Check_Close_Episode = True 

End If 

rstCheck. Close 



• All Assessments must be finished 

w = 0 

v = v + 1 

rstCheck. Open "Select Distinct Description From Mobil ityAssessmen ts A, InterventionCodes IC ■ & 
"Where A. Consumer ID = ° & CustomerlD & _ 

■ And A. Agency = & AgencyCode & "' And A. CaseNumber ■ ' * & CaseNumber & _ 
. "■ And A .Episode = " & Episode & _ 

" And (FinishDate IS NULL Or FinishDate = .#12:00:00 PM#) " & _ 

■ And A. Intervention^ = IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck. RecordCount > 0 Then 

tmpBuf (v) = vbNewLine & "There is a Mobility Assessment that is not complete" 
Check_Close_Episdde = True 
End If 



r s tCheck . Clos e 
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w = 0 , 
v = v + 1 

rstCheck. Open "Select Distinct Description From ComputerAssessment A, InterventionCodes IC ■ & 
"Where A. Consumer ID = " & Customer ID & _ 

0 And A. Agency = ,n & AgencyCode & a 1 And A. CaseNumber = * n & CaseNumber & _ 
" » And A. Episode = " & Episode & _ 

■ And (FinishDate IS NULL Or FinishDate = #12:00:00 PM#) tt & _ 

0 And A. interventions = IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck.RecordCount > 0 Then 

tmpBuf (v) = vbNewLine & "There is a Computer Assessment that is not complete" 
End If 

rstCheck. Close 

w = 0 

v « v + 1 

rstCheck. Open ."Select Distinct Description From Employment Assessment A, InterventionCodes IC 

"Where A.ConsumerlD = " & Customer ID & _ 

" And A. Agency = ,w & AgencyCode & And A. CaseNumber = ,w & CaseNumber & _ 
n • And A. Episode = " & Episode & _ 

■ And (FinishDate IS NULL Or FinishDate - #12:00:00 PM#) " & _ 

n And A.InterventionID = IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck.RecordCount > 0 Then 

tmpBuf (v) = vbNewLine & "There is a Employment Assessment that is not complete 
Check_Close_Episode = True 
End If 

rstCheck. Close 

w ^ 0 

v = v + 1 

rstCheck. Open "Select Distinct Description From ILAssessment A, InterventionCodes IC ■ & _ 
"Where A.ConsumerlD = a & Customer ID & _ 

" And A. Agency = ,n & AgencyCode & "' And A. CaseNumber = 1 " & CaseNumber & _ 
"' And A. Episode = " & Episode & 

" And (FinishDate IS NULL Or FinishDate = #12:00:00 PM#) " & 

■ And A.InterventionID = IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 



If rstCheck.RecordCount >" 0 Then 

tmpBuf (V) = vbNewLine & "There is a IL Assessment that is not complete" 
Check_Close_J3pisode = True 
End If 

rstCheck . Close 

w = 0 t 
v = v + 1 

rstCheck. Open "Select Distinct Description From SocialAssessment A, InterventionCodes IC " I 

"Where A.ConsumerlD = " & Customer ID & _ 
" And A. Agency = ,n & AgencyCode & ■' And A. CaseNumber = • " & CaseNumber & _ 

11 • And A. Episode = " & Episode & 
" And (FinishDate IS NULL Or FinishDate = #12:00:00 PM#) " & _ 
" And A.InterventionID » IC.Code", cnn, adOpenForwardOnly, adLockReadOnly 

If rstCheck.RecordCount > 0 Then ■ 
tmpBuf (v) = vbNewLine & "There is a Social Work Assessment that is not complete 
End If 

rstCheck. Close 

■ All Interventions must be closed 



w = 0 



f 
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rstCheck. Open "Select Distinct Description From Interventions A, Int erven tionCodes IC 0 & _ 
"Where A . ConsumerlD = ■ & Customer ID & _ 

" And A. Agency = ' " & AgencyCode & 01 And A.CaseNumber = ■ ° & CaseNumber & _ 
"■ And A. Episode = " & Episode & _ 

» And (EndDate IS NULL Or EndDate = #12:00:00 PM#) n & _ 

° And A. Interventions = IC.Code", cnn, adOpenForwardOnly, adliOckReadOnly 

If rstCheck.RecordCount > 0 Then 
With rstCheck 

While Not (.EOF) 
If w >' 0 Then 

tmpBuf(v) » tmpBuf <v) & " and " 
End If 

tmpBuf(v) = tmpBuf (v) & ! [Description] 
♦ MoveNext 
w = w + 1 
Wend 
End With 

tmpBuf (v) * vbNewLine & "There are ■ & tmpBuf (v) & ° Interventions that are not completed" 
Check_Close_Episode = True 
End If 

rstCheck . Close 
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If Check_Closej_Episode = True Then 
For w = 0 To 9 

tmpMessage - tmpMessage & tmpBuf (w) 
Next 

MsgBox tmpMessage, vbOKOnly, "Mandatory Items" 
End If 



Exit Function 

errSave: * 

MsgBox Err. Description, vbCritical + vbOKOnly, "Check_Cl6se_Episode" 
End Function 

Private Sub txtTriage_Change ( Index As Integer) 

If Index = 6 Or Index = 9 Or Index = 13 Or Index = 17 Then 
If ken (txtTriage (Index) ) = 4 Then 

If Not IsNumeric (Mid ( txtTriage ( Index) , 2 , 3 ) ) Then 

MsgBox "Please enter numberic number for phone number!", vblnf ormation + vbOKOnly, " Pfc 
ne Number" ■ 1 

txtTriage (Index) = Mid (txtTriage (Index) , 1, 2) 
txtTriage (Index) -Seistart =2 
Else 

txtTriage (Index) - txtTriage (Index) & »)-» 

txtTriage (Index) .SelStart =7 - 
End If 

El self lien ( txtTriage ( Index ) ) = 9 Then 

If Not IsNumeric (Mid (txtTriage (Index) , 7, 3)) Then 

MsgBox "Please enter numberic number for phone number!", vblnf ormation + vbOKOnly, " Ph 
ne Number" 

txtTriage (Index) « Mid (txtTriage (Index) , 1, 6) 
txtTriage (Index). SelStart*- 7 
Else ' 

txtTriage (Index) = txtTriage (Index) & 
txtTriage (Index) .SelStart = 11 
End if 

Elself Len ( txtTriage ( Index) ) = 14 Then 

If Not IsNumeric (Mid ( txtTriage ( Index) , 11, 3)) Then 

MsgBox "Please enter numberic number for phone number!", vblnf ormation + vbOKOnly, " Ph 
ne Number" 
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txtTriage < Index) = Mid (txtTr i age (Index) , 1, 10) 
txtTriage ( Index) . SetFocus 
End If 
End If 
End If 
End Sub 

Private Sub txtTr iage_Click( Index As Integer) 
If Index s= 19 Then 

If (Check_Close_Episode = True) Then 

txtTriage (19) .Locked = True 
Else 

txtTriage (19) -Locked = False 
End If 
End If 
End Sub 

Private Sub txtTriage_GotFocus ( Index As Integer) 

If Index = 6 Or Index = 9 Or* Index = 13 Or Index = 17 Then 
If txtTriage (Index) = nu Then 
txtTriage (Index) = "(* 
txtTriage (.Index) .SelStart = 2 
End If 
Elself Index = 19 Then 

If (Check_Close_Episode = True) Then 

txtTriage (19) .Locked = True 
Else 

txtTriage (19) .Locked = False 
End If 
End If 



End Sub 



Private Sub txtTriage_KeyUp ( Index As Integer, KeyCode As Integer, Shift As Integer) 

If Index = 6 Or Index = 9 Or Index = 13 Or Index = 17 Then 
If KeyCode = vbKeyBack Then 
txtTriage (Index) = n ( ° 
txtTriage (Index) .SelStart = 2 
End If 
End If 
End Sub 

Private Sub txtTriage_Lost Focus (Index As Integer) 
Dim in t Age As Long 
Dim today As Date 

today = Now 

If Index = 0 Then 

If IsDate ( txtTriage ( Index) ) then 

intAge = DateDif f ( °yyyy" , txtTriage (Index)', today) 

If today < DateSerial (Year (today) , Month ( txtTriage (Index) ) , Day (txtTriage (Index) ) ) Then i: 
Age = intAge - 1 

txtTriage (20) « intAge 
End If 
Elself Index = 1 Then 

If CheckForShftTab Then 
cboYesNo(2) .SetFocus 
Elself cboYesNo(2) = "No" Then 

tabTriage.Tab = 1 
End If 
Elself Index = 2 Then 

If cboYesNo (2) .List Index = 1 Then txtTriage (Index) ■= 00 
Elself Index = 4 Then 

If CheckForShftTab Then 

If cboYesNo (9) .Text = "No" Then 
cboYesNo ( 9 ) . SetFocus 
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Elself cboYesNo(9) .Text = "Yea 8 And IstHealthCondit ion. Selected (28) Then 

txtTriage (3) .SetFocus 
Elself cboYesNo(9) -Text = "Yes" And Not IstHealthCondit ion. Selected (28) Then 

IstHealthConcLi tion . SetFocus 
End If 
End If 

Elself Index = 6 Or Index = 13 Or Index = 17 Then 

If Trim ( txtTriage ( Index) ) = "(" Then txtTriage( Index) » 
Elself index = 9 Then 

If Trim <txtTriage( Index ) ) = "(" Then txtTriage (Index) = ."" 

If CheckForTab Then tabTriage . Tab = 2 
Elself Index = 10 Then 

If CheckForTab Then tabTriage. Tab = 6 
Elself Index = 13 Then 

If CheckForTab Then 1 
If cboAcceptReject(l) .Text <> "Accept" Then txtTriage (15) .SetFocus 

End if 
Elself Index = 19 Then 

If CheckForTab Then tabTriage . Tab = 7 
End If 
End Sub 

Private Sub txtTriage_Vali date (Index As Integer, Cancel As Boolean) 

If 'Index = 0 And Trim ( txtTriage ( 0 ) ) <> "" Then 
If Not IsDate (txtTriage (0) ) Then 

MsgBox "Please enter your birth day!", vblnformation + vbOKOnly, tt Birth Day" 
txtTriage (0) » " " 
Cancel = True 
End If 
Elself Index = 1 Then 

If Trim(txtTriage(l) ) <> "" Then 

If Not. IsNumeric( txtTriage (1) ) Then 

MsgBox "Please enter your age when you lost vision into this field!", vblnformation + 
OKOnly, "Age at onset" • 
Cancel = True 
End If 
End If 

Elself Index = 2 Then » 

If Trim( txtTriage (2) ) <> "" Then 
If Not IsDate (txtTriage (2 ) ) Then 

MsgBox "Please enter date when you last see your doctor! ", vblnformation + vbOKOnly, " 
test Date to see eye doctor " 
Cancel = True 
End If 
End If 
Elself Index » 14 Then 

If Trim( txtTriage ( 14 ) ) <> ■ ■ Then 

If Not IsDate ( txtTriage ( 14 ) ) Then ■ 

MsgBox "Please enter date for your eye surgery or laser treatments J n , vblnformation + 
OKOnly, D Eye Surgery" 
Cancel = True 
End If 

End If , 
End If' 
End Sub 

Private Function getTabCaption ( tablndex As Integer) As String 



Select Case tablndex 
Case 0 

getTabCaption = 
Case 1 

getTabCaption = 
Case 2 

getTabCaption = 
Case 3 

getTabCaption = 
Case 4 

getTabCaption = 



"A. Demographics" 
"B. Health" * 
"C. Problem ID" 
"D. Problem ID" 
"E. Risk Factors" 



n F . Recommendations * 
°G. Eye Report" 
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Case 5 

getTabCaption = 

Case 6 

getTabCaption = 

Case 7 

getTabCaption 
End Select 

End Function 

Private Function AcceptRecommendationO As Boolean 
Dim i As Integer 

For i = 0 To cboAcceptReject. Count - 1 

If cboAcceptReject (i) .Text = "Accepted" Then 
AcceptRecommendation = True 
Exit For 
End If 
Next 

End Function * 
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Option Explicit 

Private IsNewRecord As Boolean 
Private SequenceNo As Long 
Private InterventionSequence As Long 
Private rstVisit As ADODB . Recordset 

Private Sub cmdClose_Click( ) 
Unload Me 
End Sub 

Private Sub cmdNew_Click( ) 

clearData cboStaffs, False 
clearData cboServiceUnitType, False 
clearData cboServiceMode, False 
clearData cboServiceSession, False 
clearData cboDuration, False 
txtServiceDate = B " 

IsNewRecord = True 
cmdSave . Enabled = True 
End Sub 

Private Sub cmdNext_Click( ) 
Dim i As Integer 
Dim j As Integer 

SavelnfoToDB 

With rstVisit 
.MoveNext 

If Not (.EOF) Then 

If ! tServiceDate] - "12:00:00 PM" Then 

txtServiceDate = ° M 
Else 

txtServiceDate = I [ServiceDate] * 
End If 

SequenceNo = ! [VisitsSeq] 
LoadDa t aToCont r ols r s tvi sit, 
LoadDataToCon trols rstvisi t , 
LoadDataToControls rstVisit, 
LoadDataToControls rstVisit, 
• ■ LoadDataToControls rstVisit, 
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cboStaffs, False 
cboServiceUnitType, False 
cboServiceMode, False . 
cboServiceSession, False 
cboDuration, False 



txtServiceDate . SetFocus 
txtCurrent = .AbsolutePosition 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 
• cmdPrevious . Enabled = False 
cmdNext . Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPrevious . Enabled = True 
cmdNext . Enabled - True . 
Elself .AbsolutePosition = .RecordCount Then 
cmdPrevious . Enabled = True 
cmdNext . Enabled = False 
End If 
End If 
End If 
End With 



End Sub 

Private Sub cmdPrevious^ Click ( ) 
Dim i As Integer 
Dim j As integer 



SavelnfoToDB 



txtServiceDate . SetFocus 

txt Current = .AbsolutePosition* 

If .RecordCount > 1 Then 

if .AbsolutePosition = 1 Then 
cmdPrevious . Enabled = False 
cmdNext. Enabled- = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPrevious . Enabled = True 
cmdNext .Enabled = True 
Elself .AbsolutePosition = .RecordCount Then 
cmdPrevious . Enabled = True 
cmdNext . Enabled = False 
End If 
End If 
End If 
End With 
End Sub 

Private Sub cmdSave_Click ( ) 
SavelnfoToDB 

,MsgBox "Successfully save the inf ormation ! " , vbOKOnly, "Save Info" 
End Sub 

Private Sub FornuI»oad() 

Dim i As. Integer, j As Integer 

Dim IndexNo As Integer 

On Error GoTo Errhandler 

txtFirstName = FirstName 
txtLastName = LastName 
txtCaseNumber = CaseNumber. 

txtlntervention = f rmlnterventionl . txt Intervention 
interventionSequence = f rmlnt erven t ionl .SequenceNo 
LoadControlsItems cboStaffs, False 
LoadControl si terns cboServiceUnitType, False 
LoadControlsItems cboServiceMode, False 
LoadControlsItems cboServiceSession, False 
LoadControlsItems cboDuration, False 

Set rstVisit = New ADODB . Recordset 
rstVisit .CursorLocation = adUseClient 

rstVisit .Open "Select * From Visits Where ConsumerID=" & CustomerlD & " And Agency = ■ ■ & J 
AgencyCode & " • And CaseNumber = ; • ■ &* CaseNumber & " | And InterventionID = 1 & _ ' 
f rmlnterventionl . InterventionCode & ■ 1 And InterventionSequence = " & InterventionSequence & 
" Order by VisitsSeq DESC", cnn, adOpenDynamic , adLockOptimistic 

With rstVisit 

txtTotal =■ .RecordCount 

If Not- (.BOF And .EOF) Then 

If .RecordCount > 1 Then cmdNext . Enabled = True 

If ! [ServiceDate) » "12:00:00 PM" Or Trim( ! (ServiceDate] & vbNullString) = "" Then 
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With rstVisit 

. MovePrevious 

If Not ( . BOF) Then 

If I [ServiceDate] = "12:00:00 PM" Then 
txtServiceDate = " n « 
. Else 

txtServiceDate = ! [ ServiceDate] 
End If 

SequenceNo = ! [VisitsSeq] 

LoadDataToControls rstVisit, cboStaffs,. False 
LoadDataToControls rstVisit, cboServiceUnitType, False 
LoadDataToControls rstVisit, cboServiceMode, False 
LoadDataToControls rstVisit, cboServiceSession, False 
LoadDataToControls rstVisit, cboDuration, False 
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txtServiceDate = 00 
Else 

txtServiceDate = ! [ServiceDate] 
End If 

SequenceNo = ! [VisitsSeq] 
LoadDataToControls rstVisit, 
LoadDataToControls. rstVisit, 
LoadDataToControls rstVisit, 
LoadDataToControls rstVisit, 
LoadDataToControls rstVisit, 
End If 



cboS taf f s , False 
cboServiceUnitType, False 
cboServiceMode , False 
cboServiceSession, False 
cboDuration, False 



If .AbsolutePosition < 0. Then 

txtCurrent = 0 
Else 

txtCurrent = .AbsolutePosition 
End If 

End With 



Exit Sub 
Errhandler : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Form Load" 
End Sub 



Private Sub ForttuUnload (Cancel As Integer) 
•Dim response As Integer 



'response = MsgBox ( "Would you like save the Visit information ?", vbQuestion + vbYesNo, "C 

•) 

•If response = vbYes Then 

•MsgBox "Please use Save button to save it!", vbrnf ormation + vbOKOnly, "Close" 

•Cancel = True 
•Else 

If rstVisit .State = adStateppen Then rstVisit .Close 
Set rstVisit = Nothing , 
Set frmVisitsl = Nothing 1 

. ! End If 
End Sub 

Private Sub Savelnf 0T0DB { ) 
Dim tmpDate As Date 
Dim tmpStaf f As String 
Dim tmpType As String 
Dim tmpMode As String 
Dim tmpSession As String 
Dim tmpDuration As String 
Dim tmpPosition As Long 

On Error G0T0 Errhandler 

If cboStaffs .List Index = -1 Then- 

tmpStaff = nn 
Else 

tmpStaff ■ cboStaffs. ItemData (cboStaffs. Listlndex) 
End If 

If cboServiceUnitType. Listlndex = -1 Then 

tmpType = " " 
Else 

tmpType = cboServiceUnitType. It emData (cboServiceUnitType -Listlndex) 
End If 

If cboServiceSession. Li st Index = -1 Then 

tmpSession = " " • 
Else * 

tmpSession = cboServi ceSession.lt emData (cboServiceSession. List Index) 
End If 
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If cboServiceMode. Lis tlndex = -1 Then 

tmpMode = DD s 
Else 4 

tmpMode = cboServiceMode . ItemData (cboServiceMode. List Index) 
End If 

If cboDuration.Listindex = -1 Then 

tmpDuration « ° " 
Else 

tmpDuration « cboDuration .ItemData (cboDurat ion. List Index) 
End If 

If Trim(txtServiceDate) = n " Then 

tmpDate = "12:00:00 PM° 
Else 

tmpDate = txtServiceDate.Text 
End If 

If (rstVisit.BOF And rs tVi si t .EOF) Or IsNewRecord Then 

cnn. Execute "INSERT INTO Visits (ConsumerlD, Agency, Episode, CaseNumber, Interventions, " 
" InterventionSequence, ServiceDate, Staff Name, Type, Mode, Duration, SessionType) V* 
S ( ■ & Customer ID & ■ , ' n & _ 

. Agencycode & ■ ' , " & Episode & " , ' " & CaseNumber & " 1 , * * & _ 
frmlnterventionl.InterventionCode & 0 ' , ■ & interventionSequence & ■ , ■ ■ & tmpDate & 
• ■ & tmpStaf f & " ' , . 1 " & tmpType & " • , 1 n _ 

tmpMode & 0 ' , ' ■ & tmpDuration & ■ ' , 1 " & tmpSession & ■ ' ) ■ 

rs tvisit . Requery 

SequenceNo = rstVisit! [VisitsSeq) 
txtCurrent = rstVisit .AbsolutePosition 
txtTotal - rstVisit. RecordCount. 
IsNewRecord = False • ; 

With rstVisit 

If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 
cmdPrevious . Enabled = False 
cmdNext. Enabled = True 
Elself .AbsolutePosition < .RecordCount Then 
cmdPrevious . Enabled = True 

cmdNext . Enabled = True \ 
Elself .AbsolutePosition =. .RecordCount Then 
cmdPrevious. Enabled = True 
cmdNext .Enabled = False 
End If 
End If 
End With 
Else 

cnn. Execute "Update Visits Set StaffName = •».& tmpStaff & ■ ' , Type = »■ & tmpType & 0 • , M< 
= » » & _ 

tmpMode & ° 1 , SessionType = • » & tmpSession & » • , Duration = ■ " & tmpDuration & _ 
n • , ServiceDate = & tmpDate & Where VisitsSeq = ° & SequenceNo 

tmpPosition = rstVisit .AbsolutePosition 

rstVisit .Requery 

rstVisit. AbsolutePosition = tmpPosition 
End If 
Exit Sub 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save Infor to DB" 
End Sub 

Private Sub txtServiceDate_Validate (Cancel As Boolean) 

If Trim(txtServiceDate) = °° Then * 
Cancel = False 

Elself Not IsDate(txtServiceDate) Then . 

MsgBox "Please enter 'date for Service Date!", vblnformation + vbOKOnly, "ServiceDate 
Cancel » True 
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End If 
End Sub 



Private Sub cmdClose_Click( ) 

Unload Me 
End Sub 

Private Sub cmdHints_Click{ ) 
Dim response As Integer 

Str = "Here is a list of shortcut keys to help you navigate more quickly through this applicati 
° & vbNewLine & vbNewLine & _ 

"Press Alt S to save a screen 0 & vbNewLine & _ 

"Press Alt C to close a screen" & vbNewLine & _ 

"Press Alt P to go to the Previous Page" & vbNewLine & _ 

"Press Alt N to go to the Next Page" 
response = MsgBox(Str, vbOKOnly, ■■) 
End Sub 

• Private Sub cmdSearch_Click () 
f rmSearchMenu - Show 
Unload Me 

End Sub 1 
Private Sub cmeWelcom_Click( ) 

Str a "Welcome to the Electronic Vision Rehabilitation Record" & vbNewLine & _ 
"Copyright 2002 Lighthouse International" & vbNewLine & _ 
"Property of Lighthouse International" & vbNewLine & _ 
"Unauthorized use is - prohibited" & vbNewLine & vbNewLine & _ 

"Press the OK button to continue then press Alt H for listing of shortcut keys" 

response ■ MsgBox(Str, vbOKOnly, "Welcome") 
End Sub 

Private Sub FornuActivate ( ) . 
Me. Refresh 

End Sub % 

Private Sub FomuLoadO 

Set cnn = New ADODB. Connection . 

cnn.CursorLocation = adUseClient 

cnn. Open n DSN=miniEVRR" ' 

lblVersion = App.Majpr & "." &App. Minor & "." & App. Revision 



'elcome - 1 
Dim Str, response As String 



End Sub 
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Public Customer ID As Long 

Public AgencyCode As String 

Public Address As String 

Public PhoneNo As String 

Public. FirstName As String 

Public LastName As String 

Public Episode As Long 

Public CaseNutnber As String 

Public cnn As ADODB. Connect ion 

Public ILSequenceNo As Long 

Public SQLString As String 

Public DiagnosisArray{1017) As String 

Public DiaghosisString(26) As String 

Public VisualFieldArray(ll) As String 

Public Declare Function GetKeyboardState Lib t, user32° (pbKeyState As Byte) As Long 

Public Function CheckForTab ( ) As Boolean 
Const VKJTAB = &H9 
Const VK_SHIFT = &H10 
Dim btArray(255) As Byte 

. Call GetKeyboardState (btArray( 0) ) 

If ((btArray(VieSHIFT) And &H80) <> &H80) And < (bt Array (VK_TAB) And &H80) » &H80) Then 

CheckForTab = True 
End If 

End Function 

Public Function CheckForShf tTab ( ) As Boolean 
Const VKJTAB = &H9 - 
Const VK^SHIFT = &H10 
Dim btArray(255) As Byte 



Call GetKeyboardState (btArray(O) ) 

d 

\ 



If ( (btArray(VK_SHIFT) And &H80) = &H80) And { (bt Array (VK^TAB) And &H80) = &H80) Then 

CheckForShf tTab = True , 
End If 



End Function 

Public Sub LoadControlsItems(ByVal tmpControls As Object, IsControlArray) •Just add items to 

ch ComboBox and List Box 

Dim i As integer 

Dim IndexNo As Integer 

Dim tmpRst As New ADODB . Recordset 

On Err GoTo Errhandler 

If IsControlArray Then r 'for control array cases . 

tmpRst. Open "Select * From " & Mid( tmpControls (0) .Name, 4), cnn, adOpenForwardOnly, adLockRe 
Only 

* For i = 0 To tmpControls. Count - 1 
With tmpRst 
.MoveFirst 
While (Not .EOF) 

If tmpControls (0) .Name = °cboDiagnosis° Then 
. tmpControls ( i ) . I temData < tmpControls ( i ) . Newlndex) = IndexNo 
DiagnosisArray( IndexNo) = I [Code] 
IndexNo = IndexNo +1 
Else ' * 

tmpControls (i) .Addltem .Fields. Item ( "description 0 ) 'Add item to comt 

or list Box • . t ^ _ . 

tmpControls (i) .ItemData (tmpControls (i) .Newlndex) = .Fields . I tern ( "Code ) 

End If 
.MoveNext 
Wend 
End With 



• 



Next . 

Else 'for single combobox or listbox cases 

If tmpControls.Name = °cboStaffs° Then 

tmpRst.Open "Select * From ° & Mid (tanpCont rols. Name, 4) & a Order by Staf fName". , cnn, add 
nForwardOnly, adLockReadOnly 

Else 

tmpRst.Open "Select * From ■ & Mid (tmpControls .Name, 4), cnn, adOpenForwardOnly, adLockRec 

Only 

End If 

With tmpRst 
.MoveFirst 
While (Not . EOF) 

If tmpControls.Name = "cboStaffs" Then 

tmpControls.Addltem .Fields . Item ( "Staf f Name 0 ) 'Add item to. combo or list Box 
tmpControls . ItemData ( tmpControls .Newlndex) = .Fields . ItemCID" ) 
Else , 

tmpControls.Addltem .Fields . I tern ( "Description" ) 

tmpControls. ItemData ( tmpControls. Newlndex) = . Fields . I tern ( "Code" ) 
End If 
.MoveNext 
Wend 
End With 
End If 
tmpRst. Close 
Set rsttmp = Nothing 
Exit Sub 

Errhandler : 

MsgBox Err. Description, vbCritical + vbOKOnly, "Load Control Items" 
End Sub 

Public Sub LoadDataToControls(ByVai tmpRst As Recordset, ByVal tmpControls As Object, IsArray As 
Boolean) 

Dim i As Integer . 
Dim j As Integer 
Dim Jc As Integer 

Dim tmpStr As String • 

On Error GoTo Errhandler 

With tmpRst 

If IsArray Then 

If TypeOf tmpControls (0). Is TextBox Then 
For i = 0 To tmpControls .Count - 1 
'Debug. Print i 

If tmpControls (i) .Tag = "FinishDate" Or tmpControls (i) .Tag = "AssessmentDate" Or _ 
tmpControls (i) .Tag = "PriorDate- Or tmpControls (i) .Tag = "RegistrationDate" Or _ 
tmpControls (i) -Tag = "LastEyeExam" Or tmpControls (i) .Tag = "EpisodeCloseDate" Or 
tmpControls (i) .Tag = "EyeSurgeryDate" Or tmpControls (i) .Tag = ■ PeriodFrom" Or _ 
tmpControls (i) .Tag = "PeriodTo" Or tmpControls (i) .Tag = "Birthdate" Or _ 
tmpControls (i) .Tag = "IieavingTimel" Then 

If .Fields. Item (tmpControls <i) .Tag) = "12:00:00 PM n Or IsNull ( .Fields . Item (tmpCor 
rols ( i ) . Tag ) ) Then 

' tmpControls (i) .Text = "° 

Else 

tmpControls (i) .Text = . .Fields . Item (tmpControls (i) .Tag) .Value »& vbNullString 
End If 
Else 

tmpControls (i) .Text = . Fields. It em (tmpCont rols (i) .Tag) .Value & vbNullString 
End If 
Next 

filself TypeOf tmpControls (0) Is CheckBox Then r 
For i = 0 To tmpControls .Count - 1 

If Trim < .Fields. I tern (tmpControls (i) .Tag) .Value & vbNullString) e ° n Then 

tmpControls* (i) .Value = 0 
Else 

tmpControls <i) .Value = . Fields . Item (tmpControls (i) .Tag) .Value 
End If 
Next 
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El self TypeOf tmpControls (0) Is ComboBox Then 
For i = -0 To tmpControls -Count - 1 

If tmpControls (0) .Name = "cboDiagnosis" Then 

If Trim( .Fields. Item( tmpControls (i) .Tag) & vbNullString) = nn Then 

tmpControls (i ) .Listlndex = -1 
Else 

For j = 0 To UBound(DiagnosisArray) 

If DiagnosisArray(j) = .Fields . I tern (tmpControls (i) .Tag) Then 
k = j 
Exit For 

. End If ... 
Next 

tmpControls (i) .Listlndex = k 
End If 

Elself tmpControls (0) .Name - "cboVisualField" Then 

If Trim( .Fields. Item( tmpControls (i) .Tag) & vbNullString) « Then 

tmpControls (i) .Lis tlndex = -1 
Else 

For j = 0 To UBound(VisualFieldArray) 

If VisualFieldArray(j) = -Fields . Item (tmpControls (i) .Tag) Then 
k = j 
Exit For 
End If 
Next 

tmpControls (i) .Listlndex = k 
End If 

If Trim( , Fields . item ( tmpControls { i) .Tag) & vbNullString) = ""Then 

tmpControls (i) .Listlndex = -1* 
Else 

For j = 0 To tmpControls (i) .ListCount - 1 

If tmpControls ( i) .ItemData(j) = CLng( .Fields. It em (tmpControls (i) .Tag) .Valu. 

Then 

k - j 
" Exit For 
End If 
Next 

tmpControls (i) -Listlndex = k 
• End If * 
End If 
Next 

Elself TypeOf tmpControls (0) Is ListBox Then 
For i = 0 To tmpControls. Count - 1 

tmpStr = . Fields. Item( tmpControls (i) .Tag) & vbNullString 
For j s l To Len(tmpStr) 

If Mid( tmpStr, j, 1) = "1" Then 

tmpControls (i) .Selected (j - 1) = True 
Else 

tmpControls (i) .Selected(j -1)*= False 
End If 
Next 
Next 

tmpStr = nn 
End If 
* Else 

If TypeOf tmpControls Is ListBox Then 

tmpStr = . Fields . Item ( tmpControls . Tag) & vbNullString 
For i = 1 To Len( tmpStr) 

If Mid(tmpStr, i, 1) = "1° Then 

tmpControls. Selected (i - 1) = True 
Else 

tmpControls. Selec ted (i - 1) = False 
End If 
Next 

Elself TypeOf tmpControls Is TextBox Then 

If tmpControls. Tag = "CompletionDate" Or tmpControls .Tag = "AuthS tart Date 0 Or _ 
tmpControls. Tag = w AuthEndDate° Then 
If ..Fields .Item (tmpControls. Tag) = "12:00:00 PM" Or I sNull ( .Fields. It em (tmpControls 

ag) ) Then 

tmpControls *» "" 
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Else 

tmpControls = . Fields . I tern (tmpControls -Tag) .Value 
End If ■ 
Else 

tmpControls « .Fields. Item (tmpControls .Tag) .Value & vbNullString •Ken add VBNULLf 

ng 8/9/02 

End If 
Else 

If .Fields. Item (tmpControls. Tag) & vbNullString « " ■ Then 
tmpControls . Listlndex = -1 
• Else 

•For i a 0 To tmpControls. Li stCount - 1 

If tmpControls. ItemData(i) = CLng { .Fields . Item (tmpControls .Tag) .Value) Then 
j = i 
Exit For 
End If 
. Next 

tmpControls. Listlndex « j 
End If 
End If 
End If 
End With 
Exi t Sub 

► • 

Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Load data to Controls" 
End Sub 

Public Sub clearData(ByVal tmpControls As Object, IsArray As Boolean) 
Dim i As Integer 

If IsArray Then •„ 'for control array case 

If TypeOf tmpControls (0) Is TextBox Then 
For i « 0 To tmpControls. Count - 1 

tmpControls (i) .Text = 
Next 

Elself TypeOf tmpControls (0) Is ComboBox Then 
For i = 0 To tmpControls. Count - 1 

tmpControls (i) .Listlndex = -1 
Next 

* Elself TypeOf tmpControls (0) Is CheckBox Then 
For i = 0 To tmpControls. Count - 1 

tmpControls (i) .Value = 0 
Next 
End If 

Else 'for single control case 

If TypeOf tmpControls Is ListBox Then 

For i - 0 To tmpControls. ListCount - 1 

tmpControls. Selected (i) = False 
Next 
Else 

tmpControls. Listlndex = -1 
End If 
End If 
End Sub 

Public Sub GoalObjectives(ByVal tmpForm As Form, InterventionID As String, SequenceNo As Long) 

Dim i As Integer 

Dim SQLStr As String 

Dim GoalVar As Long 

Dim tmpvar As Long 

Dim ObjectiveVar As Long 

Dim rst As New ADODB . Recordset 

'get GoallD and ObjectivelD by tagName 
On Error GoTo Errhandler 

For i a- 0 To tmpForm.cboAgree. Count - 1 

If tmpForm.cboAgree (i) .Text = "Yes 0 Then 

rst. Open "Select Goal ID, ObjectivelD From Objectives Where AliasName & tmpForm . cboAgi 



(i) .Tag & 



cnn, adOpenForwardOnly, adLockReadOnly 
GoalVar = rst-; [GoallD] 
ObjectiveVar = rst! [ObjectivelD] 
• rst. Close 

rst. Open -Select *.From ProgressReport Where ConsumerID=- & CustomerlD &■ ' And Episode= 
Episode & _^ mterventionlD - & InterventionID & • • And AssessmentSequence = ". & Sequenc 

"~ cnn. adOpenForwardOnly, adLockReadOnly 

If rst.UOF And rst. EOF Then 'check the record existence ^ a ^ m ^ Wetventi 

SQLStr = -insert into ProgressReport (ConsumerlD. Agency, Episode, CaseNumber.Irvterventi 

& ~ -AssessmentSequence, EntryDate) Values [" & CustomerlD & »,•• & AgencyCode & & 

sode & _ „ .„ & caseNumber & & InterventionID & & SequenceNo & -,Now<))" 

rs^iSquery ■ requery the rst recordset to get the ProgressSeq No. used by next 

ordset . 

End If 

tmpVar = rst I [ProgressSeq] 
rst -Close 

rst. Open "Select * Prom GoalAchieve Where ConsumerlD- ■ &' CustomerlD & ■ And Episode= 0 

iS ° de & ~- And InterventionID = • - & InterventionID & - And ProgressSeq - " & tmpVar & _ 
■ And GoallD = • & GoalVar, cnn, adOpenForwardOnly, adLockReadOnly . 

ogressSeq." *^ alJD ^ tryDate) Values r & CustomerlD & & AgencyCode & . - & Episode & ■ 

t CaseNumber^ Tn & Intervent;ionID & „ §m & tmpVar & & GoalVar & VNow(>)" 

cnn. Execute SQLStr 
rst. Requery 
End If 

tmpVar = rst!Goal&eq ^ 
rst. Close 

rst. Open -Select * From ObjectiveAchieve Where Consumer^" & CustomerlD & • And Episo 
& Episode InterventionID . & In terventionID >fr - And GoalSeq = - & tmpVar & ■ And Go 
' " * " GoalVar & • And ObjectivelD = - & ObjectiveVar, cnn, adOpenForwardOnly, adLockReadC 

ID ' G ° alS %oall5, ObjectivelD, EntryDate) Values (" & CustomerlD & & AgencyCode & & I 

6 & W,,a CaieNumber & »', ; » & InterventionID & & tmpVar & - # - & GoalVar & & Objectd 

& \Now())" 

cnn. Execute SQLStr 
End If 
rst. Close 
End If 
Next 
Exit Sub 



MsgBox E^r! Description, vbCritical + vbOKOnly. -Goals & Objectives- 
End Sub 

Public Function S avebataToDB(ByVal tmpForm As Form, ByVal *** ordset ' * yVal tmpCo1 

llection, mterventionCode As String, Is2ndTable As Boolean) As Boolean . 
Dim i As Integer 
Dim j As Integer 

Dim tmpStr As String ^ 

Dim IndexWo As Long 

Dim rst As ADODB. Recordset 
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On Error GoTo Errhandler 

' With tmpRst 

If (.EOF And .BOF) Or tmpForm*. IsNewRecord Then 
vAddNew 

.Fields. I tern ( "Consumer ID" ) « CustomerlD 

.Fields. I tern ("Agency") = AgencyCode 

. Fields. It em ( "Casenumber" ) = CaseNumber 

If tmpForm.Name <> "frmTriage" And tmpForm. Name <> "frmEyeData 0 Then 
.Fields. I tern ("Episode") a Episode 
. .Fields. item ( "intervention^" ) = InterventionCode ' 
End If 

If tmpForm.Name => "frmlLAssessment" And Is2ndTable .Then . Fields . I tern { "Assessment Sequence 
= ILSequenceNo 
End If 

For i 3 1 To tmpCol . Count 
•Debug. Print i 

If TypeOf tmpCol(i) Is ListBox Or TypeOf tmpCol(i) Is ComboBox Or TypeOf tmpCol(i) Is Te: 
ox Then 'for single control case 

If TypeOf tmpCol(i) Is ListBox Then 

For j=0 To tmpCol (i) .ListCount - 1 
If tmpCol(i) .Selected(j) Then 

tmpStr = tmpStr & "1" 
Else 

tmpStr = tmpStr & "0" 
End If 
Next 

. Fields. It em (tmpCol(i) .Tag) = tmpStr 

tmpStr = ww 
Elself TypeOf tmpCol (i) Is TextBox Then 

. Fields. Item(tmpCol(i) .Tag) = tmpCol ( i ). Text 
Else 

If tmpCol (i) .Listlndex = -1 Then 

.Fields. It em ( tmpCol (i) .Tag) = * a 
Else " ' 

.Fields. It em (tmpcol(i) .Tag) = tmpCol (i) .ItemData (tmpCol (i) .Lis tlndex) 
End . If 
End If 
.Update 

Else 'for control collection case 

, If TypeOf tmpCol(i) (0) Is CheckBox Then 
For j = 0 To tmpCol (i) .Count - 1 

. Fields . Item ( tmpCol ( i ) (j) .Tag) = tmpCol(i) (j) .Value 
Next 
. Update 

Elself TypeOf tmpCol<i) (0) Is TextBox Then 
For j = 0 To tmpCol (i) .Count - 1 
Debug. Print j 

If tmpCol (i) (j) .Tag = "FinishDate" Or tmpCol (i) (j ) .Tag = "LeavingTimel" _ 

Or tmpCol (i) (j) .Tag = "AssessmentDate" Or tmpCol (i) (j ) .Tag a "PriorDate" _ 
Or tmpCol (i) (j) .Tag = "LastEyeExam" Or tmpCol (i) (j) .Tag = " Ey eSurgeryDate" 
Or tmpCol (i) (j) .Tag = "EpisodeCloseDate" Then ~* 
If Trim( tmpCol (i) ( j) ) = Then 

.Fields. Item(tmpCol(i) (j) .Tag) = "12:00:00 PM" 
Else 

. Fields . I tern ( tmpCol ( i ) ( j ) . Tag) = CDate (tmpCol (i) (j ) ) 
End If 
Else 

. Fields. I tem(tmpCol(i) (j) .Tag) = Trim( tmpCol (i) (j ) ) 
End "If 
Next 
.Update 

Elself TypeOf tmpCol (i) (0) Is ListBox Then 
For j = 0 To tmpCol (i) .Count - l 

For k = 0 To tmpCol <i) (j ) .ListCount - 1 
If tmpCol (i) (j) .Selected(k) Then 

tmpStr = tmpStr & °1» 
Else 
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tmpStr = tmpStr & n 0 n 
• End If 
Next 

. Fields. Itemt tmpCol (i)(j) .Tag) = tmpStr 
■ tmpStr = 0 ■ " 
Next 
Else 

For J = 0 To tmpCol (i) .Count - 1 
•Debug. Print j 

If tmpCol (i) (0) .Name - "cboDiagnosis" Then . 
<: if tmpCol(i) (j) -Iiistlndex = -1 Then 

. Fields. Item(tmpCoMi) lj) .Tag) = 
Else 

IndexNo = tmpCol(i) ( j ) . ItemData(tmpCol (i) (j) .List Index) 
. Fields. Item ( tmpCol (i) (j) .Tag) = DiagnosisArray(IndexNo) 
End If 

Elself tmpCol(i) (0) .Name = n cboVisualField° Then 
If tmpCol(i) (j) .List Index - -1 Then 
. Fields. Item(tmpCol (i) (j) .Tag) « " tt 

E1S IndexNo = tmpCol (i) (j) .ItemData ( tmpCol (i) (j) .Listlndex) 

. Fields. Item(tmpCoKi) <j) .Tag) = Vi sua lFieldArray (IndexNo) 
End If 
Else 

If tmpCol(i) (j) .List Index = -1 Then 
. Fields ..Item(tmpCol(i) (j) .Tag) » 

E1Se Fields.Item(tm P Col(i) (j) .Tag) - tmpCol(i) (j) . ItemData ( tmpCol ( i Y ( j ) .List 

x) 

End If 
End If 
Next 
.Update 
End If 
End If 
Next 
. Requery 

If Not Is2ndTable Then j 

If tmpForm.Name <> "f rmTriage" Then 

tmpForm. txtCurrentRecord = . Absolut ePos it ion 

Else ■ 
tmpForm. txtEpisode = ! [Episode] 

End If 

If ! [FinishDate] = "12:00:00 PM» Then *If filedate empty, save -12:00:00 PM« i 

fault a 

tmpForm.cmdSave. Enabled = True 

tmpForm.cmdClear.Enabled = False Goal/Object:ive ^ lock save* But 

S If (tmpForm.Name <> "frmTriage" And tmpForm.Name <> "frmEyeData") Then 
GoalObjectives tmpForm, In t erven tionCode, ! [Assessment Sequence 3 
. tmpForm. isFileDateChecked =* True. 

tmpForm. cmdPrint. Enabled = True • : 
End If 



Else 



tmpForm.cmdSave. Enabled = False 
tmpForm.cmdClear.Enabled = True 

End If. 

tmpForm-. txtRecordNo = .RecordCount 
If .RecordCount > 1 Then 

If .AbsolutePosition = 1 Then 

"tmpForm. cmdPreviousRecord . Enabled = False 
tmpForm. cmdNextRecord . Enabled = True 
Elself .AbsolutePosition < -RecordCount Then 
tmpForm. cmdPreviousRecord. Enabled = True 
tmpForm. cmdNextRecord. Enabled = True 
Elself .RecordCount = .AbsolutePosition Then 
tmpForm. cmdPreviousRecord. Enabled = True 
tmpForm. cmdNextRecord. Enabled = False 
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End If 
End If 
End If 
End With 

SaveDataToDB = True 
Exit Function 
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Errhandler: 

MsgBox Err. Description, vbCritical + vbOKOnly, "Save to DB° 
SaveDataToDB = False 
End Function 
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The operation and interface of additional facets of the present invention, including 
regulatory compliance, billing, calendar, and additional analysis and reporting is 
substantially similar to those listed above and will be apparent to service providers and 
other users of the present invention. Additionally, although the present invention and 
5 preferred embodiments have been described in considerable detail, modifications and 
other versions are possible and have been contemplated in the appended claim. 
Therefore, the spirit and scope of the appended claim should not be limited to the 
description of the preferred versions contained herein. 
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CLAIMS 

I claim: 

5 A method of facilitatiBg the management of consumer care, services and data, the method 
comprising: storing clinical pathway templates, said template being a pre-determined 
consumer care and service path; assigning a template to a given consumer upon initial 
data entry; deciding at least one clinical pathway at a data point for said consumer 
corresponding to a decision point within said template; tailoring said template at least 

10 once adjusting for the consumers needs within predetermined paths; displaying said 
. adjusted template on a screen reflecting consumer needs; storing templates entered 
relative to the consumer needs; storing data entered into said templates; providing a 
modified consumer pre-determined template; providing access to said stored data and 
templates; manipulating stored data and templates to display consumer goals and 

15 objectives; in the form of progress providing an appointment scheduler, providing 
detailed functional questions in assessment areas; providing uniform forms; providing 
standardization of service quality with said forms and analyses; providing consistency of 
interviews with scripts, prompts and reminders; providing informed consent data and 
HIPAA requirement data; manipulation of data and templates to provide consumer 

20 improvement; manipulation of data and templates to provide service provider 
improvement; manipulation of data and templates to provide clinical pathway method 
improvement; manipulate data to provide reports; provide quality anaylsis; provide 
billing computations; provide electronic billing external parties; provide corrective 
actions; provide a plurality of protection levels for consumer data and templates; 

25 displaying requested data on at least one computer screen; recording all changes made to 
consumer templates. 
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ABSTRACT 

A method and system for vision rehabilitation services consumer care is provided 
Clinical pathways and templates are selected based on consumer data entered and may be 
tailored to the consumer's needs and requirements. Consumer data is securely exchanged 
via the Internet between a central computer and consumer care provider computer to 
enable the method and system to perform program analysis, aid in and perform 
evaluations, track data, generate reports, standardize care, provide security, schedule 
appointments, monitor quality control, record and measure progress and variances, 
coordinate billing and payment, and reduce administrative cost 
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